Details

Time bar (total: 3.8s)

analyze159.0ms (4.2%)

Algorithm
search
Search
TrueOtherFalseIter
0%6.2%93.8%0
0%6.2%93.8%1
3.1%3.1%93.8%2
3.1%3.1%93.8%3
4.7%1.6%93.8%4
4.7%1.6%93.8%5
5.5%0.8%93.8%6
5.5%0.8%93.8%7
5.8%0.4%93.8%8
5.8%0.4%93.8%9
6%0.2%93.8%10
6%0.2%93.8%11
6.1%0.1%93.8%12
6.1%0.1%93.8%13
6.2%0%93.8%14
Compiler

Compiled 36 to 30 computations (16.7% saved)

sample1.9s (49.2%)

Results
1.8s8256×body128valid

preprocess74.0ms (2%)

Algorithm
egg-herbie
Rules
545×*-commutative_binary64
493×associate-*l*_binary64
470×sqr-pow_binary64
416×unswap-sqr_binary64
325×associate-*r*_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02848
15948
211048
320748
449548
5151248
6205648
7270148
8282048
9299448
10321348
11354548
12400548
13460448
022
Stop Event
saturated
node limit
Calls
Call 1
Inputs
0
1
Outputs
0
1
Call 2
Inputs
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u2)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u1))) 1/2)
Outputs
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
(fma.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)
(fma.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u2)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u1))) 1/2)
(fma.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u2)))) (cos.f64 (*.f64 u1 (*.f64 2 (PI.f64)))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u2))) (cos.f64 (*.f64 u1 (*.f64 2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u2))) (cos.f64 (*.f64 2 (*.f64 u1 (PI.f64))))) 1/2)
(fma.f64 (sqrt.f64 (*.f64 -2 (log.f64 u2))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 u1 (PI.f64))))) 1/2)
(fma.f64 (sqrt.f64 (*.f64 -2 (log.f64 u2))) (*.f64 1/6 (cos.f64 (*.f64 u1 (*.f64 2 (PI.f64))))) 1/2)
Compiler

Compiled 21 to 19 computations (9.5% saved)

simplify50.0ms (1.3%)

Algorithm
egg-herbie
Rules
818×unswap-sqr_binary64
500×sqr-pow_binary64
281×cube-prod_binary64
277×*-commutative_binary64
242×pow-sqr_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02024
13824
26524
311424
425524
573924
6100724
7133724
8262124
9272324
10288424
11309324
12340024
13382824
14439224
Stop Event
node limit
Counts
1 → 2
Calls
Call 1
Inputs
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Outputs
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
(fma.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)
(fma.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)

prune4.0ms (0.1%)

Pruning

3 alts after pruning (3 fresh and 0 done)

PrunedKeptTotal
New022
Fresh011
Picked000
Done000
Total033
Error
0.4b
Counts
3 → 2
Alt Table
StatusErrorProgram
0.4b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(fma.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)
Compiler

Compiled 112 to 98 computations (12.5% saved)

localize13.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.1b
(pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)
0.3b
(*.f64 (*.f64 2 (PI.f64)) u2)
0.4b
(*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2))

series73.0ms (1.9%)

Counts
4 → 60
Calls

15 calls:

TimeVariablePointExpression
22.0ms
u1
@0
(*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2))
22.0ms
u1
@-inf
(*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2))
12.0ms
u2
@inf
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
7.0ms
u1
@inf
(*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2))
2.0ms
u2
@0
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)

rewrite72.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
572×prod-diff_binary64
188×add-sqr-sqrt_binary64
177×pow1_binary64
176×*-un-lft-identity_binary64
176×add-log-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02051
139551
2443351
Stop Event
node limit
Counts
4 → 83
Calls
Call 1
Inputs
(*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2))
(*.f64 (*.f64 2 (PI.f64)) u2)
(pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 1/6) (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 2 (*.f64 (PI.f64) u2)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 2 (*.f64 (PI.f64) u2)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 2 (*.f64 (PI.f64) u2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 u2) (*.f64 2 (PI.f64))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 2 (*.f64 (PI.f64) u2)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (*.f64 2 (PI.f64)) 3) (pow.f64 u2 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 u2 3) (pow.f64 (*.f64 2 (PI.f64)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 2 (*.f64 (PI.f64) u2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 2 (*.f64 (PI.f64) u2))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 2 (*.f64 (PI.f64) u2))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) (cbrt.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (cbrt.f64 (*.f64 -2 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 -2) (sqrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 u1)) (sqrt.f64 -2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 -2 (log.f64 u1)) 1/4) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) 2)) (sqrt.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (*.f64 -2 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) 2) 1/2) (pow.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 -2 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 -2 (log.f64 u1)) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) -1/2)) (/.f64 1/4 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)) (cbrt.f64 (pow.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 2)) (cbrt.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)) (sqrt.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 3)) (/.f64 1 (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (-.f64 1/4 (*.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) -1/4) (/.f64 1 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (-.f64 1/4 (*.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))))) (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) -1/2) (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) -1/4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 3)) (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (-.f64 1/4 (*.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 3)) (+.f64 1/4 (-.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (*.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) -1/4) (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 3))) (neg.f64 (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (-.f64 1/4 (*.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) -1/4)) (neg.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1/4 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36))) (-.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36))) (cbrt.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))) (sqrt.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))))))

simplify71.0ms (1.9%)

Algorithm
egg-herbie
Rules
693×fma-neg_binary64
482×unswap-sqr_binary64
436×*-commutative_binary64
266×fma-def_binary64
245×associate-+l+_binary64
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
0711092
11741050
24421020
316121002
426821002
538601002
649811002
Stop Event
node limit
Counts
143 → 105
Calls
Call 1
Inputs
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 2 (*.f64 u2 (PI.f64)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))
(+.f64 1/2 (+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (*.f64 -1/3 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2))))))
(+.f64 1/2 (+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (+.f64 (*.f64 -1/3 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (*.f64 1/9 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 4)))))))
(+.f64 1/2 (+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (+.f64 (*.f64 -1/3 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 (*.f64 1/9 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (*.f64 -2/135 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 6))))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
Outputs
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 1/6 (sqrt.f64 2)))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 1/6 (sqrt.f64 2)))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 1/6 (sqrt.f64 2)))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1)))))
(*.f64 1/6 (*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 1/6 (sqrt.f64 2)))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(*.f64 2 (*.f64 u2 (PI.f64)))
(*.f64 (PI.f64) (*.f64 2 u2))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (log.f64 (/.f64 1 u1))))
(*.f64 (sqrt.f64 2) (sqrt.f64 (neg.f64 (log.f64 u1))))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -2 (log.f64 u1)))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 2) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (neg.f64 (log.f64 u1)))))))
(fma.f64 (*.f64 1/6 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) (sqrt.f64 (neg.f64 (log.f64 u1))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 2) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (neg.f64 (log.f64 u1)))))))
(fma.f64 (*.f64 1/6 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) (sqrt.f64 (neg.f64 (log.f64 u1))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 2) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (neg.f64 (log.f64 u1)))))))
(fma.f64 (*.f64 1/6 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) (sqrt.f64 (neg.f64 (log.f64 u1))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) (sqrt.f64 (log.f64 (/.f64 1 u1))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 2) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (neg.f64 (log.f64 u1)))))))
(fma.f64 (*.f64 1/6 (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) (sqrt.f64 (neg.f64 (log.f64 u1))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 2) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))
(+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 1/2)
(fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) 1/2)
(+.f64 1/2 (+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (*.f64 -1/3 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2))))))
(+.f64 1/2 (fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 -1/3 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2))))))
(+.f64 1/2 (fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 -1/3 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 u2 u2))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (*.f64 -1/3 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (*.f64 (pow.f64 (PI.f64) 2) (*.f64 -1/3 (*.f64 u2 u2))))))
(+.f64 1/2 (+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (+.f64 (*.f64 -1/3 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (*.f64 1/9 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 4)))))))
(+.f64 1/2 (fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (fma.f64 -1/3 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (*.f64 1/9 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 4)))))))
(+.f64 1/2 (fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (fma.f64 -1/3 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 u2 u2))) (*.f64 (*.f64 (*.f64 1/9 (pow.f64 u2 4)) (pow.f64 (PI.f64) 4)) (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))
(+.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (*.f64 -1/3 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2))))) (fma.f64 (*.f64 1/9 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (sqrt.f64 (*.f64 -2 (log.f64 u1))) 1/2))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (+.f64 (*.f64 1/9 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (*.f64 -1/3 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (+.f64 (*.f64 (pow.f64 u2 4) (*.f64 1/9 (pow.f64 (PI.f64) 4))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 -1/3 (*.f64 u2 u2)))))))
(+.f64 1/2 (+.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) (+.f64 (*.f64 -1/3 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 (*.f64 1/9 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (*.f64 -2/135 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 6))))))))
(+.f64 1/2 (fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (fma.f64 -1/3 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (fma.f64 1/9 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 4))) (*.f64 -2/135 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 (PI.f64) 6))))))))
(+.f64 (fma.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))) 1/2) (fma.f64 -1/3 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 u2 u2))) (fma.f64 -2/135 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 6) (pow.f64 u2 6))) (*.f64 (*.f64 (*.f64 1/9 (pow.f64 u2 4)) (pow.f64 (PI.f64) 4)) (sqrt.f64 (*.f64 -2 (log.f64 u1)))))))
(+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (*.f64 -1/3 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2))))) (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 (*.f64 1/9 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (*.f64 -2/135 (*.f64 (pow.f64 u2 6) (pow.f64 (PI.f64) 6)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 (+.f64 (*.f64 1/9 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (*.f64 -1/3 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2)))) (+.f64 1/6 (*.f64 -2/135 (*.f64 (pow.f64 u2 6) (pow.f64 (PI.f64) 6)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (+.f64 1/6 (+.f64 (*.f64 (pow.f64 u2 4) (*.f64 1/9 (pow.f64 (PI.f64) 4))) (+.f64 (*.f64 (pow.f64 (PI.f64) 2) (*.f64 -1/3 (*.f64 u2 u2))) (*.f64 (pow.f64 (PI.f64) 6) (*.f64 -2/135 (pow.f64 u2 6))))))))
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)
(+.f64 1/2 (*.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 1/6 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (cos.f64 (*.f64 (PI.f64) (*.f64 2 u2)))) 1/2)

prune180.0ms (4.8%)

Pruning

6 alts after pruning (5 fresh and 1 done)

PrunedKeptTotal
New1005105
Fresh101
Picked011
Done000
Total1016107
Error
0b
Counts
107 → 6
Alt Table
StatusErrorProgram
0.6b
(+.f64 (*.f64 (cbrt.f64 (pow.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1)))) 3)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.2b
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
1.2b
(+.f64 (*.f64 (pow.f64 (cbrt.f64 (*.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))) 3) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.5b
(/.f64 (-.f64 1/4 (*.f64 (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2) (*.f64 (*.f64 -2 (log.f64 u1)) 1/36))) (-.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (*.f64 1/6 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))))))
0.7b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (*.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) (cbrt.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Compiler

Compiled 2768 to 2120 computations (23.4% saved)

localize11.0ms (0.3%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.1b
(sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36))
0.3b
(*.f64 (*.f64 2 (PI.f64)) u2)
0.3b
(*.f64 (*.f64 -2 (log.f64 u1)) 1/36)

series7.0ms (0.2%)

Counts
3 → 48
Calls

12 calls:

TimeVariablePointExpression
1.0ms
u2
@inf
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
1.0ms
u2
@0
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
1.0ms
u1
@-inf
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
1.0ms
u1
@-inf
(*.f64 (*.f64 -2 (log.f64 u1)) 1/36)
1.0ms
u2
@-inf
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)

rewrite62.0ms (1.6%)

Algorithm
batch-egg-rewrite
Rules
520×prod-diff_binary64
170×add-sqr-sqrt_binary64
162×*-un-lft-identity_binary64
162×pow1_binary64
160×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01744
135335
2407635
Stop Event
node limit
Counts
3 → 77
Calls
Call 1
Inputs
(*.f64 (*.f64 -2 (log.f64 u1)) 1/36)
(sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36))
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (log.f64 u1) -1/18) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 2) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (log.f64 u1) -1/18)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (pow.f64 u1 -2) 1/36))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (log.f64 u1) -1/18)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))) (cbrt.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (*.f64 (log.f64 u1) -1/18)) (cbrt.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1/6 (sqrt.f64 (*.f64 -2 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 1/4) (pow.f64 (*.f64 (log.f64 u1) -1/18) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) 1/6)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1))) (pow.f64 1/36 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 -2) (sqrt.f64 (*.f64 (log.f64 u1) 1/36)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 -2) (pow.f64 (*.f64 (log.f64 u1) 1/36) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 2))) (sqrt.f64 (cbrt.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1/36 1/2) (sqrt.f64 (*.f64 -2 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 2)) 1/2) (pow.f64 (cbrt.f64 (*.f64 (log.f64 u1) -1/18)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (log.f64 u1) -1/18) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (log.f64 u1) -1/18)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (/.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) -1/2)) (/.f64 1/4 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) (pow.f64 (cbrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) 2) (cbrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) (sqrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 3)) (/.f64 1 (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) (-.f64 1/4 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (*.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) -1/4) (/.f64 1 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) (-.f64 1/4 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (*.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))) (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 1 (/.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) -1/2) (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) -1/4)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 3)) (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) (-.f64 1/4 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (*.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 3)) (+.f64 1/4 (-.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (*.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) -1/4) (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) -1/2))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 1/8 (pow.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 3))) (neg.f64 (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) (-.f64 1/4 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (*.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (neg.f64 (+.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2)) -1/4)) (neg.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) -1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1/4 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2))) (-.f64 1/2 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 1 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2)))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (cbrt.f64 (*.f64 (*.f64 (log.f64 u1) -1/18) (pow.f64 (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 2))) (cbrt.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f64 (sqrt.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) (sqrt.f64 (*.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) (cos.f64 (*.f64 2 (*.f64 (PI.f64) u2))) 1/2)))))))

simplify65.0ms (1.7%)

Algorithm
egg-herbie
Rules
739×fma-neg_binary64
480×unswap-sqr_binary64
409×*-commutative_binary64
223×associate-*l*_binary64
200×associate-+l+_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
063850
1151808
2393786
31466776
42398769
53601769
64754769
Stop Event
node limit
Counts
125 → 97
Calls
Call 1
Inputs
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 1/2 (sqrt.f64 (*.f64 -1/18 (log.f64 u1)))))
(+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 1/2 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))))))
(+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 1/2 (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 6))))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
Outputs
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (sqrt.f64 1/18))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (*.f64 -1/18 (log.f64 u1)))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))))
(+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) 1/2)
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 1/2 (sqrt.f64 (*.f64 -1/18 (log.f64 u1)))))
(fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) 1/2))
(+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (fma.f64 (*.f64 -2 (*.f64 u2 u2)) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)) 1/2))
(+.f64 1/2 (*.f64 (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) 1) (sqrt.f64 (*.f64 -1/18 (log.f64 u1)))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 1 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 1 (*.f64 -2 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2))))))
(+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 1/2 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))))))
(fma.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 4))) (fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) 1/2)))
(fma.f64 2/3 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 4) (pow.f64 u2 4))) (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (fma.f64 (*.f64 -2 (*.f64 u2 u2)) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)) 1/2)))
(+.f64 (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) 1/2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (*.f64 (pow.f64 u2 4) (*.f64 2/3 (pow.f64 (PI.f64) 4))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (+.f64 1 (*.f64 (pow.f64 u2 4) (*.f64 2/3 (pow.f64 (PI.f64) 4)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 1 (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (*.f64 -2 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2)))))))
(+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 1/2 (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 6))))))))
(fma.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 4))) (fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (+.f64 1/2 (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 6))))))))
(fma.f64 2/3 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 4) (pow.f64 u2 4))) (+.f64 (fma.f64 -4/45 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 6) (pow.f64 u2 6))) (sqrt.f64 (*.f64 -1/18 (log.f64 u1)))) (fma.f64 (*.f64 -2 (*.f64 u2 u2)) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (pow.f64 (PI.f64) 2)) 1/2)))
(+.f64 1/2 (+.f64 (*.f64 (+.f64 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6))) 1) (sqrt.f64 (*.f64 -1/18 (log.f64 u1)))) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (*.f64 (pow.f64 u2 4) (*.f64 2/3 (pow.f64 (PI.f64) 4)))))))
(+.f64 1/2 (+.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 (+.f64 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6))) (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))) (*.f64 (pow.f64 u2 4) (*.f64 2/3 (pow.f64 (PI.f64) 4)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (*.f64 -2 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2)))) (+.f64 1 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (+.f64 (+.f64 1 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6)))) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (*.f64 -2 (*.f64 (*.f64 u2 u2) (pow.f64 (PI.f64) 2)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))))
(fma.f64 (sqrt.f64 (*.f64 -1/18 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) 1/2)

prune229.0ms (6.1%)

Pruning

7 alts after pruning (5 fresh and 2 done)

PrunedKeptTotal
New1104114
Fresh314
Picked011
Done011
Total1137120
Error
0b
Counts
120 → 7
Alt Table
StatusErrorProgram
0.2b
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (sqrt.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 1)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.2b
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
0.5b
(+.f64 (*.f64 (expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.5b
(+.f64 (*.f64 (cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.7b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (*.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) (cbrt.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Compiler

Compiled 2593 to 1921 computations (25.9% saved)

localize14.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.0b
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
0.1b
(sqrt.f64 (neg.f64 (log.f64 u1)))
0.2b
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
0.3b
(*.f64 u2 (PI.f64))

series10.0ms (0.3%)

Counts
4 → 44
Calls

18 calls:

TimeVariablePointExpression
1.0ms
u1
@-inf
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
1.0ms
u1
@0
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
1.0ms
u1
@inf
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
1.0ms
u2
@0
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
1.0ms
u2
@inf
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)

rewrite58.0ms (1.5%)

Algorithm
batch-egg-rewrite
Rules
575×prod-diff_binary64
262×log1p-udef_binary64
159×add-sqr-sqrt_binary64
152×pow1_binary64
151×*-un-lft-identity_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01656
132750
2374150
Stop Event
node limit
Counts
4 → 78
Calls
Call 1
Inputs
(*.f64 u2 (PI.f64))
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(sqrt.f64 (neg.f64 (log.f64 u1)))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 u2 (PI.f64)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 u2 (PI.f64)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 u2 (PI.f64)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 u2 (PI.f64))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 u2 (PI.f64))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (*.f64 u2 (PI.f64)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (PI.f64)) u2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 u2 (PI.f64)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 u2 (PI.f64)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 u2 3) (pow.f64 (PI.f64) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (PI.f64) 3) (pow.f64 u2 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 u2 (PI.f64))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 u2 (PI.f64))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 u2 (PI.f64))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 u2 (PI.f64))))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 1/2 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 1) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)) (cbrt.f64 (pow.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (pow.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 2)) (cbrt.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)) (sqrt.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 (pow.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 3) 1/8) (+.f64 (*.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))))) (-.f64 1/4 (*.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 (*.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))))) 1/4) (-.f64 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1/2)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (sqrt.f64 (log.f64 u1)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log.f64 u1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (sqrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log.f64 u1)) (cbrt.f64 (sqrt.f64 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (sqrt.f64 (log.f64 u1))) (cbrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (log.f64 u1) 1/4) (pow.f64 (log.f64 u1) 1/4))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (log.f64 u1)) 2)) (sqrt.f64 (cbrt.f64 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 -1) (sqrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 1 1/2) (sqrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (pow.f64 (cbrt.f64 (log.f64 u1)) 2) 1/2) (pow.f64 (cbrt.f64 (log.f64 u1)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 -1 1/2) (sqrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log.f64 u1) 1/2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log.f64 u1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 u1) 3/2) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (sqrt.f64 (log.f64 u1))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log.f64 u1) 1/4) 2)))) (#(struct:change #<rule egg-rr> (2) ((x fabs.f64 (sqrt.f64 (log.f64 u1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (sqrt.f64 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (sqrt.f64 (log.f64 u1)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log.f64 u1) 3/2))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (sqrt.f64 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (sqrt.f64 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (log.f64 u1)) 1/2))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (sqrt.f64 (log.f64 u1))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (sqrt.f64 (log.f64 u1))))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (exp.f64 (log1p.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (log.f64 u1) (pow.f64 (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)) 2)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 (exp.f64 (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) (sqrt.f64 (log.f64 u1))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 1 (expm1.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2))) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (log.f64 u1) 3/2) (pow.f64 (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (*.f64 (pow.f64 (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)) 3) (pow.f64 (log.f64 u1) 3/2)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (*.f64 (log.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (sqrt.f64 (log.f64 u1)) (cos.f64 (*.f64 (*.f64 u2 (PI.f64)) 2)))))))))

simplify55.0ms (1.5%)

Algorithm
egg-herbie
Rules
741×distribute-lft-out_binary64
515×associate-*l*_binary64
428×unswap-sqr_binary64
426×associate-*r*_binary64
340×fma-def_binary64
Iterations

Useful iterations: 4 (0.0ms)

IterNodesCost
0841106
12061102
25861061
325681026
435311004
Stop Event
node limit
Counts
122 → 103
Calls
Call 1
Inputs
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)))
(+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2)))))))
(+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4))))))))
(+.f64 (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 6))))) (+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4)))))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (sqrt.f64 (neg.f64 (log.f64 u1))))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 4))))))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 6)))))))
Outputs
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) 1/2)
(+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2)))))))
(+.f64 1/2 (fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) (*.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2)))))))
(+.f64 (fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) 1/2) (*.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))) (*.f64 -2 (*.f64 u2 u2))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (sqrt.f64 1/18) (*.f64 -2 (*.f64 (sqrt.f64 1/18) (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (+.f64 1 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))) (sqrt.f64 1/18))))
(+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4))))))))
(+.f64 1/2 (fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) (fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2)))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4))))))))
(+.f64 (fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) 1/2) (fma.f64 2/3 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4)) (pow.f64 u2 4))) (*.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))) (*.f64 -2 (*.f64 u2 u2)))))
(+.f64 1/2 (fma.f64 -2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (sqrt.f64 1/18) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4))))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 (sqrt.f64 1/18) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))))) (sqrt.f64 1/18))))
(+.f64 1/2 (*.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (+.f64 1 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))))))
(+.f64 (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 6))))) (+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) (+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4)))))))))
(fma.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 6)))) (+.f64 1/2 (fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) (fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2)))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4)))))))))
(+.f64 (fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18) (fma.f64 2/3 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4)) (pow.f64 u2 4))) (*.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 2))) (*.f64 -2 (*.f64 u2 u2))))) (fma.f64 -4/45 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 6)) (pow.f64 u2 6))) 1/2))
(+.f64 1/2 (fma.f64 -4/45 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (*.f64 (pow.f64 u2 6) (pow.f64 (PI.f64) 6)))) (fma.f64 -2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (sqrt.f64 1/18) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 1/18) (pow.f64 (PI.f64) 4)))))))))
(+.f64 1/2 (+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (+.f64 1 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4)))) (sqrt.f64 1/18))) (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (*.f64 (*.f64 (pow.f64 u2 6) (pow.f64 (PI.f64) 6)) -4/45))))))
(+.f64 1/2 (*.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (+.f64 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6))) (+.f64 1 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))))))))
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 1/2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 1/18) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))))
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(+.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18))) 1/2)
(fma.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (sqrt.f64 1/18)) 1/2)
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
(fma.f64 (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (sqrt.f64 1/18)) 1/2)
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (log.f64 (/.f64 1 u1)))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (log.f64 (/.f64 1 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64)))))
(sqrt.f64 (neg.f64 (log.f64 u1)))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (sqrt.f64 (neg.f64 (log.f64 u1))))
(fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (sqrt.f64 (neg.f64 (log.f64 u1))))
(fma.f64 -2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 u2 u2))) (sqrt.f64 (neg.f64 (log.f64 u1))))
(*.f64 (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) 1) (sqrt.f64 (neg.f64 (log.f64 u1))))
(*.f64 (+.f64 1 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))) (sqrt.f64 (neg.f64 (log.f64 u1))))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 4))))))
(fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 4))))))
(fma.f64 -2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 u2 u2))) (fma.f64 2/3 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 4) (pow.f64 u2 4))) (sqrt.f64 (neg.f64 (log.f64 u1)))))
(+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (*.f64 (pow.f64 u2 4) (*.f64 2/3 (pow.f64 (PI.f64) 4))))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))) (+.f64 1 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))))))
(+.f64 (*.f64 -2 (*.f64 (pow.f64 u2 2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2)))) (+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 4)))) (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 6)))))))
(fma.f64 -2 (*.f64 (*.f64 u2 u2) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 2))) (+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (fma.f64 2/3 (*.f64 (pow.f64 u2 4) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 4))) (*.f64 -4/45 (*.f64 (pow.f64 u2 6) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 6)))))))
(+.f64 (fma.f64 2/3 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 4) (pow.f64 u2 4))) (*.f64 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (pow.f64 (PI.f64) 6)) (*.f64 -4/45 (pow.f64 u2 6)))) (fma.f64 -2 (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (pow.f64 (PI.f64) 2) (*.f64 u2 u2))) (sqrt.f64 (neg.f64 (log.f64 u1)))))
(+.f64 (*.f64 (+.f64 (*.f64 (pow.f64 u2 4) (*.f64 2/3 (pow.f64 (PI.f64) 4))) 1) (sqrt.f64 (neg.f64 (log.f64 u1)))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6))) (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2)))))))
(+.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (+.f64 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6))) (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))))))
(*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (+.f64 (*.f64 2/3 (*.f64 (pow.f64 u2 4) (pow.f64 (PI.f64) 4))) (+.f64 (*.f64 (pow.f64 u2 6) (*.f64 -4/45 (pow.f64 (PI.f64) 6))) (+.f64 1 (*.f64 -2 (*.f64 u2 (*.f64 u2 (pow.f64 (PI.f64) 2))))))))

prune84.0ms (2.2%)

Pruning

7 alts after pruning (4 fresh and 3 done)

PrunedKeptTotal
New1030103
Fresh044
Picked011
Done022
Total1037110
Error
0b
Counts
110 → 7
Alt Table
StatusErrorProgram
0.2b
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (sqrt.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 1)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.2b
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
0.5b
(+.f64 (*.f64 (expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.5b
(+.f64 (*.f64 (cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.7b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (*.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) (cbrt.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Compiler

Compiled 2335 to 1558 computations (33.3% saved)

localize14.0ms (0.4%)

Local error

Found 4 expressions with local error:

NewErrorProgram
0.1b
(log1p.f64 (*.f64 (log.f64 u1) -1/18))
0.3b
(*.f64 (*.f64 2 (PI.f64)) u2)
0.3b
(*.f64 (log.f64 u1) -1/18)
0.6b
(exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))

series72.0ms (1.9%)

Counts
3 → 36
Calls

9 calls:

TimeVariablePointExpression
36.0ms
u1
@0
(exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))
15.0ms
u1
@-inf
(exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))
14.0ms
u1
@inf
(exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))
6.0ms
u1
@-inf
(log1p.f64 (*.f64 (log.f64 u1) -1/18))
0.0ms
u1
@0
(*.f64 (log.f64 u1) -1/18)

rewrite35.0ms (0.9%)

Algorithm
batch-egg-rewrite
Rules
554×pow1_binary64
510×add-log-exp_binary64
510×expm1-log1p-u_binary64
509×log1p-expm1-u_binary64
499×add-exp-log_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0724
113123
2142423
Stop Event
node limit
Counts
3 → 51
Calls
Call 1
Inputs
(exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))
(*.f64 (log.f64 u1) -1/18)
(log1p.f64 (*.f64 (log.f64 u1) -1/18))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (*.f64 (log.f64 u1) -1/18) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 1 (*.f64 (log.f64 u1) -1/18))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (+.f64 (*.f64 (log.f64 u1) -1/18) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) (pow.f64 (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) 2) (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) (sqrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (+.f64 1 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3)) (+.f64 1 (-.f64 (*.f64 (pow.f64 (log.f64 u1) 2) 1/324) (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f64 (-.f64 1 (*.f64 (pow.f64 (log.f64 u1) 2) 1/324)) (-.f64 1 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 1) (log1p.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 2)) (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (exp.f64 (sqrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))) (sqrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (exp.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (expm1.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (*.f64 (log.f64 u1) -1/18) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (*.f64 (log.f64 u1) -1/18)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (*.f64 (pow.f64 (log.f64 u1) 2) 1/324))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (pow.f64 u1 -1/18))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f64 (-.f64 (pow.f64 u1 -1/18) 1))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (sqrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1))) (log.f64 (sqrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 0 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f64 (log.f64 (pow.f64 (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1)) 2)) (log.f64 (cbrt.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f64 (+.f64 1 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 1 (log1p.f64 (*.f64 (log.f64 u1) -1/18)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) (pow.f64 (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (pow.f64 (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 2) (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f64 (sqrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) (sqrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (pow.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (cbrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f64 (sqrt.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f64 (pow.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f64 (+.f64 (*.f64 (log.f64 u1) -1/18) 1))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f64 (pow.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f64 (log.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f64 (log1p.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))))))))

simplify49.0ms (1.3%)

Algorithm
egg-herbie
Rules
481×unsub-neg_binary64
455×distribute-rgt-in_binary64
356×distribute-neg-in_binary64
332×fma-def_binary64
248×distribute-lft-in_binary64
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
023264
148252
288252
3163252
4327252
5801252
62522252
73967252
84738252
Stop Event
node limit
Counts
87 → 62
Calls
Call 1
Inputs
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
Outputs
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 (*.f64 -1/18 (log.f64 u1)) 1)
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1))))
(fma.f64 -1/18 (log.f64 u1) 1)
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 1/18 (log.f64 (/.f64 1 u1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))
(*.f64 -1/18 (log.f64 u1))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 (*.f64 -1/18 (log.f64 u1)) 1))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 1/18 (log.f64 (/.f64 1 u1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))
(log.f64 (+.f64 1 (*.f64 -1/18 (+.f64 (*.f64 -1 (log.f64 (/.f64 -1 u1))) (log.f64 -1)))))
(log.f64 (fma.f64 -1/18 (log.f64 u1) 1))
(log1p.f64 (*.f64 -1/18 (log.f64 u1)))

prune113.0ms (3%)

Pruning

7 alts after pruning (3 fresh and 4 done)

PrunedKeptTotal
New79079
Fresh033
Picked011
Done033
Total79786
Error
0b
Counts
86 → 7
Alt Table
StatusErrorProgram
0.2b
(+.f64 (*.f64 (sqrt.f64 (*.f64 (*.f64 -2 (log.f64 u1)) 1/36)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (pow.f64 (*.f64 -2 (log.f64 u1)) 1/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.4b
(+.f64 (*.f64 (sqrt.f64 (-.f64 (exp.f64 (log1p.f64 (*.f64 (log.f64 u1) -1/18))) 1)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.2b
(fma.f64 (sqrt.f64 1/18) (*.f64 (sqrt.f64 (neg.f64 (log.f64 u1))) (cos.f64 (*.f64 2 (*.f64 u2 (PI.f64))))) 1/2)
0.5b
(+.f64 (*.f64 (expm1.f64 (log1p.f64 (sqrt.f64 (*.f64 (log.f64 u1) -1/18)))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.5b
(+.f64 (*.f64 (cbrt.f64 (pow.f64 (*.f64 (log.f64 u1) -1/18) 3/2)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
0.7b
(+.f64 (*.f64 (*.f64 (/.f64 1 6) (*.f64 (cbrt.f64 (*.f64 -2 (log.f64 u1))) (cbrt.f64 (sqrt.f64 (*.f64 -2 (log.f64 u1)))))) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Compiler

Compiled 1867 to 1508 computations (19.2% saved)

regimes244.0ms (6.4%)

Accuracy

Total -0.8b remaining (-327.4%)

Threshold costs -0.8b (-327.4%)

Counts
48 → 1
Compiler

Compiled 885 to 664 computations (25% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
*-commutative_binary64
+-commutative_binary64
sub-neg_binary64
1-exp_binary64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01727
12627
22727
Stop Event
saturated
Calls
Call 1
Inputs
(+.f64 (*.f64 (sqrt.f64 (-.f64 (fma.f64 -1/18 (log.f64 u1) 1) 1)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
Outputs
(+.f64 (*.f64 (sqrt.f64 (-.f64 (fma.f64 -1/18 (log.f64 u1) 1) 1)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)
(+.f64 (*.f64 (sqrt.f64 (+.f64 (fma.f64 -1/18 (log.f64 u1) 1) -1)) (cos.f64 (*.f64 (*.f64 2 (PI.f64)) u2))) 1/2)

end98.0ms (2.6%)

Stop Event
fuel
Compiler

Compiled 163 to 129 computations (20.9% saved)

Profiling

Loading profile data...