Details

Time bar (total: 2.3s)

analyze1.0ms (0%)

Algorithm
search
Search
TrueOtherFalseIter
0%0.1%99.9%0
0.1%0%99.9%1
Compiler

Compiled 33 to 24 computations (27.3% saved)

sample1.6s (70.1%)

Results
1.6s8253×body128valid
1.0msbody256valid

preprocess40.0ms (1.7%)

Algorithm
egg-herbie
Rules
601×fma-def_binary32
498×fma-neg_binary32
174×cancel-sign-sub-inv_binary32
94×sub-neg_binary32
89×unsub-neg_binary32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01640
14032
210632
322232
454032
5115332
6198732
7232532
8240532
9241632
033
Stop Event
saturated
saturated
Calls
Call 1
Inputs
0
1
2
Outputs
0
1
2
Call 2
Inputs
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
(+.f32 (-.f32 1 uy) (*.f32 uy maxCos))
(+.f32 (-.f32 1 maxCos) (*.f32 maxCos ux))
(+.f32 (-.f32 1 ux) (*.f32 ux uy))
Outputs
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
(fma.f32 ux maxCos (-.f32 1 ux))
(-.f32 (fma.f32 ux maxCos 1) ux)
(+.f32 (-.f32 1 uy) (*.f32 uy maxCos))
(-.f32 1 (-.f32 uy (*.f32 maxCos uy)))
(fma.f32 maxCos uy (-.f32 1 uy))
(-.f32 (fma.f32 maxCos uy 1) uy)
(+.f32 (-.f32 1 maxCos) (*.f32 maxCos ux))
(+.f32 (-.f32 1 maxCos) (*.f32 ux maxCos))
(fma.f32 ux maxCos (-.f32 1 maxCos))
(-.f32 (fma.f32 ux maxCos 1) maxCos)
(+.f32 (-.f32 1 ux) (*.f32 ux uy))
(fma.f32 ux uy (-.f32 1 ux))
(-.f32 (fma.f32 ux uy 1) ux)
Compiler

Compiled 10 to 7 computations (30% saved)

simplify15.0ms (0.6%)

Algorithm
egg-herbie
Rules
199×fma-def_binary32
155×fma-neg_binary32
47×cancel-sign-sub-inv_binary32
34×sub-neg_binary32
26×unsub-neg_binary32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0710
1158
2358
3728
41678
53618
66188
77658
87978
98028
Stop Event
saturated
Counts
1 → 2
Calls
Call 1
Inputs
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
Outputs
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
(fma.f32 ux maxCos (-.f32 1 ux))
(-.f32 (fma.f32 ux maxCos 1) ux)

prune2.0ms (0.1%)

Pruning

2 alts after pruning (2 fresh and 0 done)

PrunedKeptTotal
New112
Fresh011
Picked000
Done000
Total123
Error
0.0b
Counts
3 → 1
Alt Table
StatusErrorProgram
0.0b
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
Compiler

Compiled 36 to 24 computations (33.3% saved)

localize16.0ms (0.7%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(*.f32 ux maxCos)
0.0b
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))

series5.0ms (0.2%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
1.0ms
ux
@inf
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
1.0ms
ux
@-inf
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
1.0ms
ux
@0
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
0.0ms
ux
@0
(*.f32 ux maxCos)
0.0ms
maxCos
@inf
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))

rewrite45.0ms (2%)

Algorithm
batch-egg-rewrite
Rules
836×log1p-expm1-u_binary32
836×expm1-log1p-u_binary32
81×add-sqr-sqrt_binary32
79×*-un-lft-identity_binary32
79×pow1_binary32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0714
115412
2220812
Stop Event
node limit
Counts
2 → 54
Calls
Call 1
Inputs
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
(*.f32 ux maxCos)
Outputs
((#(struct:change #<rule egg-rr> (2) ((x -.f32 1 (-.f32 ux (*.f32 ux maxCos)))))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (exp.f32 (log1p.f32 (fma.f32 ux maxCos (-.f32 1 ux)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (/.f32 (pow.f32 (-.f32 1 ux) 2) (-.f32 1 (+.f32 ux (*.f32 ux maxCos)))) (/.f32 (pow.f32 (*.f32 ux maxCos) 2) (-.f32 1 (+.f32 ux (*.f32 ux maxCos)))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (+.f32 (*.f32 ux maxCos) 1) ux)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 1 (fma.f32 ux maxCos (-.f32 1 ux)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (fma.f32 ux maxCos (-.f32 1 ux)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (cbrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))) (pow.f32 (cbrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (pow.f32 (cbrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))) 2) (cbrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (sqrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))) (sqrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (+.f32 (pow.f32 (-.f32 1 ux) 3) (pow.f32 (*.f32 ux maxCos) 3)) (/.f32 1 (+.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 (*.f32 ux maxCos) (-.f32 (*.f32 ux maxCos) (-.f32 1 ux))))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (-.f32 (pow.f32 (-.f32 1 ux) 2) (pow.f32 (*.f32 ux maxCos) 2)) (/.f32 1 (-.f32 1 (+.f32 ux (*.f32 ux maxCos)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 1 (/.f32 (+.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 (*.f32 ux maxCos) (-.f32 (*.f32 ux maxCos) (-.f32 1 ux)))) (+.f32 (pow.f32 (-.f32 1 ux) 3) (pow.f32 (*.f32 ux maxCos) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 1 (/.f32 (-.f32 1 (+.f32 ux (*.f32 ux maxCos))) (-.f32 (pow.f32 (-.f32 1 ux) 2) (pow.f32 (*.f32 ux maxCos) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (+.f32 (pow.f32 (-.f32 1 ux) 3) (pow.f32 (*.f32 ux maxCos) 3)) (+.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 (*.f32 ux maxCos) (-.f32 (*.f32 ux maxCos) (-.f32 1 ux)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (+.f32 (pow.f32 (-.f32 1 ux) 3) (pow.f32 (*.f32 ux maxCos) 3)) (+.f32 (pow.f32 (*.f32 ux maxCos) 2) (-.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 (*.f32 (-.f32 1 ux) ux) maxCos))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 (pow.f32 (-.f32 1 ux) 2) (pow.f32 (*.f32 ux maxCos) 2)) (-.f32 1 (+.f32 ux (*.f32 ux maxCos))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (neg.f32 (+.f32 (pow.f32 (-.f32 1 ux) 3) (pow.f32 (*.f32 ux maxCos) 3))) (neg.f32 (+.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 (*.f32 ux maxCos) (-.f32 (*.f32 ux maxCos) (-.f32 1 ux))))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (neg.f32 (-.f32 (pow.f32 (-.f32 1 ux) 2) (pow.f32 (*.f32 ux maxCos) 2))) (neg.f32 (-.f32 1 (+.f32 ux (*.f32 ux maxCos)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 1 (pow.f32 (-.f32 ux (*.f32 ux maxCos)) 3)) (+.f32 1 (+.f32 (*.f32 (-.f32 ux (*.f32 ux maxCos)) (-.f32 ux (*.f32 ux maxCos))) (-.f32 ux (*.f32 ux maxCos)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 1 (*.f32 (-.f32 ux (*.f32 ux maxCos)) (-.f32 ux (*.f32 ux maxCos)))) (+.f32 1 (-.f32 ux (*.f32 ux maxCos))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 (pow.f32 (*.f32 ux maxCos) 2) (pow.f32 (-.f32 1 ux) 2)) (-.f32 (*.f32 ux maxCos) (-.f32 1 ux)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (fma.f32 ux maxCos (-.f32 1 ux)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (fma.f32 ux maxCos (-.f32 1 ux)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (fma.f32 ux maxCos (-.f32 1 ux))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (fma.f32 ux maxCos (-.f32 1 ux)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (exp.f32 (fma.f32 ux maxCos (-.f32 1 ux))))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 1 (expm1.f32 (fma.f32 ux maxCos (-.f32 1 ux)))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (fma.f32 ux maxCos (-.f32 1 ux)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f32 (expm1.f32 (fma.f32 ux maxCos (-.f32 1 ux))))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (fma.f32 ux maxCos (-.f32 1 ux))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (log.f32 (fma.f32 ux maxCos (-.f32 1 ux))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (*.f32 (log.f32 (fma.f32 ux maxCos (-.f32 1 ux))) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 1 (-.f32 1 ux) (*.f32 ux maxCos))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 1 (*.f32 ux maxCos) (-.f32 1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 ux maxCos (-.f32 1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 maxCos ux (-.f32 1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (pow.f32 (cbrt.f32 (*.f32 ux maxCos)) 2) (cbrt.f32 (*.f32 ux maxCos)) (-.f32 1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (pow.f32 (cbrt.f32 (-.f32 1 ux)) 2) (cbrt.f32 (-.f32 1 ux)) (*.f32 ux maxCos))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (sqrt.f32 (*.f32 ux maxCos)) (sqrt.f32 (*.f32 ux maxCos)) (-.f32 1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (sqrt.f32 (-.f32 1 ux)) (sqrt.f32 (-.f32 1 ux)) (*.f32 ux maxCos))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f32 (exp.f32 (log1p.f32 (*.f32 ux maxCos))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (*.f32 ux maxCos) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (*.f32 ux maxCos)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (*.f32 ux maxCos)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (*.f32 ux maxCos) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (*.f32 ux maxCos) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (pow.f32 (exp.f32 ux) maxCos))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 1 (expm1.f32 (*.f32 ux maxCos))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (*.f32 ux maxCos) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f32 (expm1.f32 (*.f32 ux maxCos)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (*.f32 ux maxCos)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (log.f32 (*.f32 ux maxCos)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (*.f32 (log.f32 (*.f32 ux maxCos)) 1))))))

simplify22.0ms (1%)

Algorithm
egg-herbie
Rules
185×fma-def_binary32
158×fma-neg_binary32
31×sub-neg_binary32
25×unsub-neg_binary32
22×cancel-sign-sub-inv_binary32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
017303
145267
2107267
3227267
4461267
5662267
6762267
7780267
Stop Event
saturated
Counts
102 → 64
Calls
Call 1
Inputs
1
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(*.f32 (-.f32 maxCos 1) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos))))
(+.f32 1 (*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos)))))
(+.f32 1 (*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos)))))
(+.f32 1 (*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos)))))
(-.f32 1 ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(*.f32 maxCos ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(*.f32 maxCos ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
Outputs
1
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (+.f32 maxCos -1) ux)
(-.f32 (*.f32 maxCos ux) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos))))
(*.f32 (+.f32 maxCos -1) ux)
(-.f32 (*.f32 maxCos ux) ux)
(+.f32 1 (*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos)))))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(+.f32 1 (*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos)))))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(+.f32 1 (*.f32 -1 (*.f32 ux (+.f32 1 (*.f32 -1 maxCos)))))
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 1 ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(*.f32 maxCos ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(*.f32 maxCos ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(-.f32 (+.f32 1 (*.f32 maxCos ux)) ux)
(+.f32 1 (*.f32 (+.f32 maxCos -1) ux))
(-.f32 (fma.f32 maxCos ux 1) ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)
(*.f32 maxCos ux)

prune41.0ms (1.8%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New62264
Fresh000
Picked011
Done000
Total62365
Error
0b
Counts
65 → 3
Alt Table
StatusErrorProgram
0.0b
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
0.0b
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
0.4b
(*.f32 (-.f32 (pow.f32 (-.f32 1 ux) 2) (pow.f32 (*.f32 ux maxCos) 2)) (/.f32 1 (-.f32 1 (+.f32 ux (*.f32 ux maxCos)))))
Compiler

Compiled 873 to 512 computations (41.4% saved)

localize17.0ms (0.7%)

Local error

Found 2 expressions with local error:

NewErrorProgram
0.0b
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
0.0b
(*.f32 (-.f32 maxCos 1) ux)

series5.0ms (0.2%)

Counts
2 → 27
Calls

12 calls:

TimeVariablePointExpression
1.0ms
ux
@-inf
(*.f32 (-.f32 maxCos 1) ux)
1.0ms
ux
@inf
(*.f32 (-.f32 maxCos 1) ux)
1.0ms
maxCos
@-inf
(*.f32 (-.f32 maxCos 1) ux)
1.0ms
ux
@0
(*.f32 (-.f32 maxCos 1) ux)
0.0ms
maxCos
@inf
(*.f32 (-.f32 maxCos 1) ux)

rewrite39.0ms (1.7%)

Algorithm
batch-egg-rewrite
Rules
799×pow1_binary32
742×log1p-expm1-u_binary32
742×expm1-log1p-u_binary32
79×add-sqr-sqrt_binary32
76×*-un-lft-identity_binary32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0717
115215
2204215
Stop Event
node limit
Counts
2 → 53
Calls
Call 1
Inputs
(*.f32 (-.f32 maxCos 1) ux)
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 maxCos ux) (*.f32 -1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 ux maxCos) (*.f32 ux -1))))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (fma.f32 (+.f32 maxCos -1) ux 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 (+.f32 (pow.f32 maxCos 3) -1) ux) (fma.f32 maxCos maxCos (+.f32 maxCos 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 (fma.f32 maxCos maxCos -1) ux) (+.f32 maxCos 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 ux (+.f32 (pow.f32 maxCos 3) -1)) (fma.f32 maxCos maxCos (+.f32 maxCos 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 ux (fma.f32 maxCos maxCos -1)) (+.f32 maxCos 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (pow.f32 (exp.f32 ux) (+.f32 maxCos -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 1 (expm1.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f32 (expm1.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (log.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (*.f32 (log.f32 (*.f32 (+.f32 maxCos -1) ux)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x -.f32 (exp.f32 (log1p.f32 (fma.f32 (+.f32 maxCos -1) ux 1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (/.f32 1 (-.f32 1 (*.f32 (+.f32 maxCos -1) ux))) (/.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (-.f32 1 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 1 (fma.f32 (+.f32 maxCos -1) ux 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (fma.f32 (+.f32 maxCos -1) ux 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (cbrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)) (pow.f32 (cbrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (pow.f32 (cbrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)) 2) (cbrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (sqrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)) (sqrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (+.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3)) (/.f32 1 (+.f32 1 (-.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (*.f32 (+.f32 maxCos -1) ux)))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (-.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2)) (/.f32 1 (-.f32 1 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 1 (/.f32 (+.f32 1 (-.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (*.f32 (+.f32 maxCos -1) ux))) (+.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 1 (/.f32 (-.f32 1 (*.f32 (+.f32 maxCos -1) ux)) (-.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (+.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3)) (+.f32 1 (-.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (+.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3)) (+.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (-.f32 1 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2)) (-.f32 1 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (neg.f32 (+.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3))) (neg.f32 (+.f32 1 (-.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (*.f32 (+.f32 maxCos -1) ux)))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (neg.f32 (-.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2))) (neg.f32 (-.f32 1 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) 1) (-.f32 (*.f32 (+.f32 maxCos -1) ux) 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (fma.f32 (+.f32 maxCos -1) ux 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (fma.f32 (+.f32 maxCos -1) ux 1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (fma.f32 (+.f32 maxCos -1) ux 1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (fma.f32 (+.f32 maxCos -1) ux 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (exp.f32 (fma.f32 (+.f32 maxCos -1) ux 1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 1 (expm1.f32 (fma.f32 (+.f32 maxCos -1) ux 1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (fma.f32 (+.f32 maxCos -1) ux 1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f32 (expm1.f32 (fma.f32 (+.f32 maxCos -1) ux 1)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (fma.f32 (+.f32 maxCos -1) ux 1)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (*.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)) 1))))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 1 (*.f32 (+.f32 maxCos -1) ux) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (+.f32 maxCos -1) ux 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 ux (+.f32 maxCos -1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (pow.f32 (cbrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 2) (cbrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x fma.f32 (sqrt.f32 (*.f32 (+.f32 maxCos -1) ux)) (sqrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 1)))))

simplify25.0ms (1.1%)

Algorithm
egg-herbie
Rules
186×fma-def_binary32
186×fma-neg_binary32
59×cancel-sign-sub-inv_binary32
32×sub-neg_binary32
31×associate--r+_binary32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
013201
131173
246173
364173
496173
5155173
6311173
7522173
8733173
9822173
10846173
11847173
Stop Event
saturated
Counts
80 → 65
Calls
Call 1
Inputs
(*.f32 -1 ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 maxCos ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 maxCos ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) 1)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(*.f32 maxCos ux)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(*.f32 maxCos ux)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
1
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
Outputs
(*.f32 -1 ux)
(neg.f32 ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 maxCos ux)
(*.f32 ux maxCos)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 maxCos ux)
(*.f32 ux maxCos)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) 1)
(fma.f32 -1 ux 1)
(-.f32 1 ux)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(*.f32 maxCos ux)
(*.f32 ux maxCos)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(*.f32 maxCos ux)
(*.f32 ux maxCos)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux maxCos (-.f32 1 ux))
1
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (+.f32 -1 maxCos))
(-.f32 (*.f32 ux maxCos) ux)

prune48.0ms (2.1%)

Pruning

2 alts after pruning (1 fresh and 1 done)

PrunedKeptTotal
New64165
Fresh101
Picked101
Done011
Total66268
Error
0b
Counts
68 → 2
Alt Table
StatusErrorProgram
0.0b
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
0.0b
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
Compiler

Compiled 775 to 579 computations (25.3% saved)

localize19.0ms (0.8%)

Local error

Found 3 expressions with local error:

NewErrorProgram
0.0b
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
0.0b
(*.f32 (+.f32 maxCos -1) ux)
0.0b
(log1p.f32 (*.f32 (+.f32 maxCos -1) ux))

series38.0ms (1.7%)

Counts
3 → 72
Calls

18 calls:

TimeVariablePointExpression
14.0ms
ux
@inf
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
12.0ms
ux
@-inf
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
2.0ms
maxCos
@inf
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
2.0ms
maxCos
@-inf
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
1.0ms
maxCos
@0
(log1p.f32 (*.f32 (+.f32 maxCos -1) ux))

rewrite44.0ms (1.9%)

Algorithm
batch-egg-rewrite
Rules
786×pow1_binary32
724×expm1-log1p-u_binary32
723×log1p-expm1-u_binary32
80×add-sqr-sqrt_binary32
78×*-un-lft-identity_binary32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0827
115826
2192826
Stop Event
node limit
Counts
3 → 65
Calls
Call 1
Inputs
(log1p.f32 (*.f32 (+.f32 maxCos -1) ux))
(*.f32 (+.f32 maxCos -1) ux)
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
Outputs
((#(struct:change #<rule egg-rr> (2) ((x +.f32 (log.f32 (sqrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))) (log.f32 (sqrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 0 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 (log.f32 (pow.f32 (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) 2)) (log.f32 (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (exp.f32 (log1p.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 1 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) (pow.f32 (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (pow.f32 (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) 2) (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (sqrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) (sqrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)) 3))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (log.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (*.f32 (log.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 maxCos ux) (*.f32 -1 ux))))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 -1 ux) (*.f32 maxCos ux))))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 ux maxCos) (*.f32 ux -1))))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 ux -1) (*.f32 ux maxCos))))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 (+.f32 -1 (pow.f32 maxCos 3)) ux) (fma.f32 maxCos maxCos (-.f32 1 (*.f32 maxCos -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 (fma.f32 maxCos maxCos -1) ux) (+.f32 maxCos 1))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 ux (+.f32 -1 (pow.f32 maxCos 3))) (fma.f32 maxCos maxCos (-.f32 1 (*.f32 maxCos -1))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (*.f32 ux (fma.f32 maxCos maxCos -1)) (+.f32 maxCos 1))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (*.f32 (+.f32 maxCos -1) ux)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (pow.f32 (exp.f32 ux) (+.f32 maxCos -1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 1 (expm1.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (*.f32 (pow.f32 (+.f32 maxCos -1) 3) (pow.f32 ux 3)))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (*.f32 (pow.f32 ux 3) (pow.f32 (+.f32 maxCos -1) 3)))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f32 (expm1.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (log.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x exp.f32 (*.f32 (log.f32 (*.f32 (+.f32 maxCos -1) ux)) 1))))))
((#(struct:change #<rule egg-rr> (2) ((x +.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))) (#(struct:change #<rule egg-rr> (2) ((x +.f32 1 (*.f32 (+.f32 maxCos -1) ux))))) (#(struct:change #<rule egg-rr> (2) ((x -.f32 (exp.f32 (log1p.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 1 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) (pow.f32 (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) 2))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (pow.f32 (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) 2) (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x *.f32 (sqrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) (sqrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (+.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 3)) (+.f32 1 (-.f32 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2) (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x /.f32 (-.f32 1 (pow.f32 (*.f32 (+.f32 maxCos -1) ux) 2)) (-.f32 1 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1) 1)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (pow.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1) 3) 1/3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (cbrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) 3)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (sqrt.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)) 2)))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (exp.f32 1) (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (exp.f32 (sqrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))) (sqrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x pow.f32 (exp.f32 (pow.f32 (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))) 2)) (cbrt.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux))))))) (#(struct:change #<rule egg-rr> (2) ((x sqrt.f32 (pow.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1) 2))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (exp.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x log.f32 (+.f32 1 (expm1.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1))))))) (#(struct:change #<rule egg-rr> (2) ((x cbrt.f32 (pow.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1) 3))))) (#(struct:change #<rule egg-rr> (2) ((x log1p.f32 (expm1.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))))) (#(struct:change #<rule egg-rr> (2) ((x expm1.f32 (log1p.f32 (+.f32 (*.f32 (+.f32 maxCos -1) ux) 1)))))))

simplify48.0ms (2.1%)

Algorithm
egg-herbie
Rules
546×distribute-rgt-in_binary32
544×distribute-lft-in_binary32
188×fma-def_binary32
155×+-commutative_binary32
141×associate-+r+_binary32
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02111799
16941588
227811350
Stop Event
node limit
Counts
137 → 146
Calls
Call 1
Inputs
(log.f32 (+.f32 (*.f32 -1 ux) 1))
(+.f32 (log.f32 (+.f32 (*.f32 -1 ux) 1)) (/.f32 (*.f32 maxCos ux) (+.f32 (*.f32 -1 ux) 1)))
(+.f32 (log.f32 (+.f32 (*.f32 -1 ux) 1)) (+.f32 (*.f32 -1/2 (/.f32 (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (/.f32 (*.f32 maxCos ux) (+.f32 (*.f32 -1 ux) 1))))
(+.f32 (log.f32 (+.f32 (*.f32 -1 ux) 1)) (+.f32 (*.f32 1/3 (/.f32 (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))) (+.f32 (*.f32 -1/2 (/.f32 (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (/.f32 (*.f32 maxCos ux) (+.f32 (*.f32 -1 ux) 1)))))
(+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))
(-.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (+.f32 (/.f32 1 (*.f32 maxCos ux)) (log.f32 ux))) (/.f32 1 maxCos))
(-.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (log.f32 ux) (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2))))))) (/.f32 1 maxCos))
(-.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (*.f32 1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)))) (+.f32 (log.f32 ux) (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)))))))) (/.f32 1 maxCos))
(+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))
(+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (/.f32 -1 maxCos) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))))
(-.f32 (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)))) (log.f32 (*.f32 -1 ux))))) (/.f32 1 maxCos))
(-.f32 (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (*.f32 1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)))) (log.f32 (*.f32 -1 ux)))))) (/.f32 1 maxCos))
(*.f32 (-.f32 maxCos 1) ux)
(+.f32 (*.f32 -1/2 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2))) (*.f32 (-.f32 maxCos 1) ux))
(+.f32 (*.f32 -1/2 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2))) (+.f32 (*.f32 1/3 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3))) (*.f32 (-.f32 maxCos 1) ux)))
(+.f32 (*.f32 -1/4 (*.f32 (pow.f32 (-.f32 maxCos 1) 4) (pow.f32 ux 4))) (+.f32 (*.f32 -1/2 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2))) (+.f32 (*.f32 1/3 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3))) (*.f32 (-.f32 maxCos 1) ux))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (*.f32 -1 (log.f32 (/.f32 1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))
(-.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (*.f32 -1 (log.f32 (/.f32 1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux)))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(-.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (*.f32 -1 (log.f32 (/.f32 1 ux))) (+.f32 (*.f32 1/3 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3)))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))
(+.f32 (log.f32 (*.f32 -1 (-.f32 maxCos 1))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))
(-.f32 (+.f32 (log.f32 (*.f32 -1 (-.f32 maxCos 1))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux)))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(-.f32 (+.f32 (log.f32 (*.f32 -1 (-.f32 maxCos 1))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (+.f32 (*.f32 1/3 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3)))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(*.f32 -1 ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 maxCos ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 maxCos ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 (-.f32 maxCos 1) ux)
(+.f32 (*.f32 -1 ux) 1)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (*.f32 -1 ux) (+.f32 1 (+.f32 (*.f32 maxCos ux) (*.f32 (+.f32 (*.f32 1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (*.f32 -1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2)))) (*.f32 (pow.f32 maxCos 2) (+.f32 (*.f32 -1 ux) 1))))))
(+.f32 (*.f32 (pow.f32 maxCos 3) (*.f32 (+.f32 (*.f32 1/3 (/.f32 (pow.f32 ux 3) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))) (+.f32 (*.f32 1/6 (/.f32 (pow.f32 ux 3) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))) (*.f32 -1/2 (/.f32 (pow.f32 ux 3) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))))) (+.f32 (*.f32 -1 ux) 1))) (+.f32 (*.f32 -1 ux) (+.f32 1 (+.f32 (*.f32 maxCos ux) (*.f32 (+.f32 (*.f32 1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (*.f32 -1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2)))) (*.f32 (pow.f32 maxCos 2) (+.f32 (*.f32 -1 ux) 1)))))))
(exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) maxCos))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (+.f32 (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) maxCos) (/.f32 (*.f32 (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (pow.f32 (-.f32 (/.f32 1 ux) 1) 2))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) (pow.f32 maxCos 2))))
(+.f32 (/.f32 (*.f32 (+.f32 (*.f32 -1/2 (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2)) (pow.f32 ux 2))) (+.f32 (*.f32 1/6 (pow.f32 (-.f32 (/.f32 1 ux) 1) 3)) (*.f32 1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) (pow.f32 maxCos 3)) (+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (+.f32 (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) maxCos) (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (pow.f32 (-.f32 (/.f32 1 ux) 1) 2)))) (pow.f32 maxCos 2)))))
(exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))
(+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1 ux) 1)) (*.f32 maxCos ux)) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))))
(+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))))) (pow.f32 maxCos 2)) (+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1 ux) 1)) (*.f32 maxCos ux)) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))))
(+.f32 (*.f32 -1 (/.f32 (*.f32 (+.f32 (*.f32 -1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))) (+.f32 (*.f32 1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))) (*.f32 -1/6 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))) (pow.f32 maxCos 3))) (+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1 ux) 1)) (*.f32 maxCos ux)) (+.f32 (/.f32 (*.f32 (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2)))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))) (pow.f32 maxCos 2)) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))))))
1
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 1 (+.f32 (*.f32 (-.f32 maxCos 1) ux) (*.f32 (+.f32 (*.f32 1/2 (pow.f32 (-.f32 maxCos 1) 2)) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 2))) (pow.f32 ux 2))))
(+.f32 1 (+.f32 (*.f32 (+.f32 (*.f32 1/6 (pow.f32 (-.f32 maxCos 1) 3)) (+.f32 (*.f32 1/3 (pow.f32 (-.f32 maxCos 1) 3)) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 3)))) (pow.f32 ux 3)) (+.f32 (*.f32 (-.f32 maxCos 1) ux) (*.f32 (+.f32 (*.f32 1/2 (pow.f32 (-.f32 maxCos 1) 2)) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 2))) (pow.f32 ux 2)))))
(exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux)))))
(+.f32 (/.f32 (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))) (*.f32 (-.f32 maxCos 1) ux)) (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))))
(+.f32 (/.f32 (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))) (*.f32 (-.f32 maxCos 1) ux)) (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))))
(+.f32 (/.f32 (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))) (*.f32 (-.f32 maxCos 1) ux)) (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))))
(exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1)))))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (*.f32 (-.f32 maxCos 1) ux)))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (*.f32 (-.f32 maxCos 1) ux)))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (*.f32 (-.f32 maxCos 1) ux)))
Outputs
(log.f32 (+.f32 (*.f32 -1 ux) 1))
(log.f32 (fma.f32 -1 ux 1))
(log1p.f32 (neg.f32 ux))
(+.f32 (log.f32 (+.f32 (*.f32 -1 ux) 1)) (/.f32 (*.f32 maxCos ux) (+.f32 (*.f32 -1 ux) 1)))
(+.f32 (log.f32 (fma.f32 -1 ux 1)) (/.f32 maxCos (/.f32 (fma.f32 -1 ux 1) ux)))
(+.f32 (log1p.f32 (neg.f32 ux)) (*.f32 (/.f32 maxCos (-.f32 1 ux)) ux))
(+.f32 (log.f32 (+.f32 (*.f32 -1 ux) 1)) (+.f32 (*.f32 -1/2 (/.f32 (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (/.f32 (*.f32 maxCos ux) (+.f32 (*.f32 -1 ux) 1))))
(+.f32 (log.f32 (fma.f32 -1 ux 1)) (fma.f32 -1/2 (/.f32 (*.f32 (*.f32 maxCos maxCos) (*.f32 ux ux)) (pow.f32 (fma.f32 -1 ux 1) 2)) (/.f32 maxCos (/.f32 (fma.f32 -1 ux 1) ux))))
(+.f32 (log1p.f32 (neg.f32 ux)) (fma.f32 -1/2 (/.f32 (*.f32 ux ux) (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 maxCos maxCos))) (*.f32 (/.f32 maxCos (-.f32 1 ux)) ux)))
(+.f32 (log1p.f32 (neg.f32 ux)) (fma.f32 -1/2 (/.f32 maxCos (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2) maxCos)) (*.f32 (/.f32 maxCos (-.f32 1 ux)) ux)))
(+.f32 (log.f32 (+.f32 (*.f32 -1 ux) 1)) (+.f32 (*.f32 1/3 (/.f32 (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))) (+.f32 (*.f32 -1/2 (/.f32 (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (/.f32 (*.f32 maxCos ux) (+.f32 (*.f32 -1 ux) 1)))))
(+.f32 (log.f32 (fma.f32 -1 ux 1)) (fma.f32 1/3 (/.f32 (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)) (pow.f32 (fma.f32 -1 ux 1) 3)) (fma.f32 -1/2 (/.f32 (*.f32 (*.f32 maxCos maxCos) (*.f32 ux ux)) (pow.f32 (fma.f32 -1 ux 1) 2)) (/.f32 maxCos (/.f32 (fma.f32 -1 ux 1) ux)))))
(+.f32 (log1p.f32 (neg.f32 ux)) (fma.f32 1/3 (/.f32 (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)) (pow.f32 (-.f32 1 ux) 3)) (fma.f32 -1/2 (/.f32 (*.f32 ux ux) (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 maxCos maxCos))) (*.f32 (/.f32 maxCos (-.f32 1 ux)) ux))))
(+.f32 (log1p.f32 (neg.f32 ux)) (fma.f32 1/3 (/.f32 (pow.f32 maxCos 3) (pow.f32 (+.f32 -1 (/.f32 1 ux)) 3)) (fma.f32 -1/2 (/.f32 maxCos (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2) maxCos)) (*.f32 (/.f32 maxCos (-.f32 1 ux)) ux))))
(+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))
(fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))
(+.f32 (log.f32 maxCos) (log.f32 ux))
(-.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (+.f32 (/.f32 1 (*.f32 maxCos ux)) (log.f32 ux))) (/.f32 1 maxCos))
(-.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (+.f32 (log.f32 ux) (/.f32 1 (*.f32 ux maxCos)))) (/.f32 1 maxCos))
(+.f32 (log.f32 maxCos) (+.f32 (log.f32 ux) (-.f32 (/.f32 1 (*.f32 ux maxCos)) (/.f32 1 maxCos))))
(+.f32 (log.f32 maxCos) (+.f32 (log.f32 ux) (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos)))
(-.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (log.f32 ux) (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2))))))) (/.f32 1 maxCos))
(-.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (+.f32 (/.f32 1 (*.f32 ux maxCos)) (+.f32 (log.f32 ux) (*.f32 -1/2 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 2) (*.f32 (*.f32 maxCos maxCos) (*.f32 ux ux))))))) (/.f32 1 maxCos))
(+.f32 (+.f32 (/.f32 1 (*.f32 ux maxCos)) (fma.f32 -1/2 (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 ux (*.f32 ux (*.f32 maxCos maxCos)))) (log.f32 ux))) (-.f32 (log.f32 maxCos) (/.f32 1 maxCos)))
(+.f32 (log.f32 maxCos) (+.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2) (*.f32 maxCos maxCos)) (log.f32 ux)) (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos)))
(-.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (*.f32 1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)))) (+.f32 (log.f32 ux) (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)))))))) (/.f32 1 maxCos))
(-.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (+.f32 (/.f32 1 (*.f32 ux maxCos)) (fma.f32 1/3 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3))) (+.f32 (log.f32 ux) (*.f32 -1/2 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 2) (*.f32 (*.f32 maxCos maxCos) (*.f32 ux ux)))))))) (/.f32 1 maxCos))
(+.f32 (log.f32 maxCos) (+.f32 (fma.f32 1/3 (/.f32 (pow.f32 (-.f32 1 ux) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3))) (fma.f32 -1/2 (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 ux (*.f32 ux (*.f32 maxCos maxCos)))) (log.f32 ux))) (-.f32 (/.f32 1 (*.f32 ux maxCos)) (/.f32 1 maxCos))))
(+.f32 (log.f32 maxCos) (+.f32 (fma.f32 1/3 (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 3) (pow.f32 maxCos 3)) (fma.f32 -1/2 (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2) (*.f32 maxCos maxCos)) (log.f32 ux))) (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos)))
(+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))
(fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))
(-.f32 (log.f32 (neg.f32 ux)) (log.f32 (/.f32 -1 maxCos)))
(+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (/.f32 -1 maxCos) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))))
(+.f32 (/.f32 1 (*.f32 ux maxCos)) (+.f32 (/.f32 -1 maxCos) (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))))
(+.f32 (-.f32 (log.f32 (neg.f32 ux)) (log.f32 (/.f32 -1 maxCos))) (+.f32 (/.f32 1 (*.f32 ux maxCos)) (/.f32 -1 maxCos)))
(+.f32 (-.f32 (log.f32 (neg.f32 ux)) (log.f32 (/.f32 -1 maxCos))) (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos))
(-.f32 (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)))) (log.f32 (*.f32 -1 ux))))) (/.f32 1 maxCos))
(+.f32 (/.f32 1 (*.f32 ux maxCos)) (-.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (fma.f32 -1/2 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 2) (*.f32 (*.f32 maxCos maxCos) (*.f32 ux ux))) (log.f32 (neg.f32 ux)))) (/.f32 1 maxCos)))
(+.f32 (-.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 ux (*.f32 ux (*.f32 maxCos maxCos)))) (log.f32 (neg.f32 ux))) (log.f32 (/.f32 -1 maxCos))) (+.f32 (/.f32 1 (*.f32 ux maxCos)) (/.f32 -1 maxCos)))
(+.f32 (-.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2) (*.f32 maxCos maxCos)) (log.f32 (neg.f32 ux))) (log.f32 (/.f32 -1 maxCos))) (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos))
(-.f32 (+.f32 (/.f32 1 (*.f32 maxCos ux)) (+.f32 (*.f32 1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3)))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (*.f32 (pow.f32 maxCos 2) (pow.f32 ux 2)))) (log.f32 (*.f32 -1 ux)))))) (/.f32 1 maxCos))
(+.f32 (/.f32 1 (*.f32 ux maxCos)) (-.f32 (fma.f32 1/3 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3))) (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (fma.f32 -1/2 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 2) (*.f32 (*.f32 maxCos maxCos) (*.f32 ux ux))) (log.f32 (neg.f32 ux))))) (/.f32 1 maxCos)))
(+.f32 (fma.f32 1/3 (/.f32 (pow.f32 (-.f32 1 ux) 3) (*.f32 (pow.f32 maxCos 3) (pow.f32 ux 3))) (-.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 ux (*.f32 ux (*.f32 maxCos maxCos)))) (log.f32 (neg.f32 ux))) (log.f32 (/.f32 -1 maxCos)))) (+.f32 (/.f32 1 (*.f32 ux maxCos)) (/.f32 -1 maxCos)))
(+.f32 (fma.f32 1/3 (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 3) (pow.f32 maxCos 3)) (-.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2) (*.f32 maxCos maxCos)) (log.f32 (neg.f32 ux))) (log.f32 (/.f32 -1 maxCos)))) (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos))
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1/2 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2))) (*.f32 (-.f32 maxCos 1) ux))
(fma.f32 -1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)) (*.f32 ux (-.f32 maxCos 1)))
(fma.f32 ux (-.f32 maxCos 1) (*.f32 (*.f32 ux ux) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 2))))
(*.f32 ux (+.f32 (*.f32 (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 2)) ux) (-.f32 maxCos 1)))
(+.f32 (*.f32 -1/2 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2))) (+.f32 (*.f32 1/3 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3))) (*.f32 (-.f32 maxCos 1) ux)))
(fma.f32 -1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)) (fma.f32 1/3 (*.f32 (pow.f32 ux 3) (pow.f32 (-.f32 maxCos 1) 3)) (*.f32 ux (-.f32 maxCos 1))))
(fma.f32 -1/2 (*.f32 ux (*.f32 ux (pow.f32 (-.f32 maxCos 1) 2))) (fma.f32 ux (-.f32 maxCos 1) (*.f32 1/3 (*.f32 (pow.f32 ux 3) (pow.f32 (-.f32 maxCos 1) 3)))))
(fma.f32 -1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)) (fma.f32 ux (-.f32 maxCos 1) (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (*.f32 1/3 (pow.f32 ux 3)))))
(+.f32 (*.f32 -1/4 (*.f32 (pow.f32 (-.f32 maxCos 1) 4) (pow.f32 ux 4))) (+.f32 (*.f32 -1/2 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2))) (+.f32 (*.f32 1/3 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3))) (*.f32 (-.f32 maxCos 1) ux))))
(fma.f32 -1/4 (*.f32 (pow.f32 (-.f32 maxCos 1) 4) (pow.f32 ux 4)) (fma.f32 -1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)) (fma.f32 1/3 (*.f32 (pow.f32 ux 3) (pow.f32 (-.f32 maxCos 1) 3)) (*.f32 ux (-.f32 maxCos 1)))))
(fma.f32 -1/4 (*.f32 (pow.f32 (-.f32 maxCos 1) 4) (pow.f32 ux 4)) (fma.f32 -1/2 (*.f32 ux (*.f32 ux (pow.f32 (-.f32 maxCos 1) 2))) (fma.f32 ux (-.f32 maxCos 1) (*.f32 1/3 (*.f32 (pow.f32 ux 3) (pow.f32 (-.f32 maxCos 1) 3))))))
(fma.f32 -1/4 (*.f32 (pow.f32 (-.f32 maxCos 1) 4) (pow.f32 ux 4)) (fma.f32 -1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)) (fma.f32 ux (-.f32 maxCos 1) (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (*.f32 1/3 (pow.f32 ux 3))))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (neg.f32 (neg.f32 (log.f32 ux))))
(+.f32 (log.f32 ux) (log.f32 (-.f32 maxCos 1)))
(+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (*.f32 -1 (log.f32 (/.f32 1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (fma.f32 -1 (neg.f32 (log.f32 ux)) (/.f32 1 (*.f32 ux (-.f32 maxCos 1)))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (log.f32 ux) (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux)))
(+.f32 (log.f32 ux) (+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (log.f32 (-.f32 maxCos 1))))
(-.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (*.f32 -1 (log.f32 (/.f32 1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux)))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (-.f32 (fma.f32 -1 (neg.f32 (log.f32 ux)) (/.f32 1 (*.f32 ux (-.f32 maxCos 1)))) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (-.f32 (+.f32 (log.f32 ux) (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux)) (/.f32 1/2 (*.f32 ux (*.f32 ux (pow.f32 (-.f32 maxCos 1) 2))))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (-.f32 (+.f32 (log.f32 ux) (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux)) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(-.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (*.f32 -1 (log.f32 (/.f32 1 ux))) (+.f32 (*.f32 1/3 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3)))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (-.f32 (fma.f32 -1 (neg.f32 (log.f32 ux)) (+.f32 (/.f32 1 (*.f32 ux (-.f32 maxCos 1))) (/.f32 1/3 (*.f32 (pow.f32 ux 3) (pow.f32 (-.f32 maxCos 1) 3))))) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (+.f32 (log.f32 ux) (+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (/.f32 (/.f32 1/3 (pow.f32 ux 3)) (pow.f32 (-.f32 maxCos 1) 3)))) (/.f32 -1/2 (*.f32 ux (*.f32 ux (pow.f32 (-.f32 maxCos 1) 2))))))
(+.f32 (log.f32 (-.f32 maxCos 1)) (+.f32 (+.f32 (+.f32 (log.f32 ux) (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux)) (/.f32 (/.f32 1/3 (pow.f32 ux 3)) (pow.f32 (-.f32 maxCos 1) 3))) (/.f32 -1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))
(fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))
(-.f32 (log.f32 (+.f32 (neg.f32 maxCos) 1)) (log.f32 (/.f32 -1 ux)))
(-.f32 (log.f32 (+.f32 1 (neg.f32 maxCos))) (log.f32 (/.f32 -1 ux)))
(+.f32 (log.f32 (*.f32 -1 (-.f32 maxCos 1))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))
(+.f32 (log.f32 (neg.f32 (-.f32 maxCos 1))) (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (/.f32 1 (*.f32 ux (-.f32 maxCos 1)))))
(+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (-.f32 (log.f32 (+.f32 (neg.f32 maxCos) 1)) (log.f32 (/.f32 -1 ux))))
(+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (-.f32 (log.f32 (+.f32 1 (neg.f32 maxCos))) (log.f32 (/.f32 -1 ux))))
(-.f32 (+.f32 (log.f32 (*.f32 -1 (-.f32 maxCos 1))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux)))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(+.f32 (log.f32 (neg.f32 (-.f32 maxCos 1))) (-.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (/.f32 1 (*.f32 ux (-.f32 maxCos 1)))) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(-.f32 (+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (-.f32 (log.f32 (+.f32 (neg.f32 maxCos) 1)) (log.f32 (/.f32 -1 ux)))) (/.f32 1/2 (*.f32 ux (*.f32 ux (pow.f32 (-.f32 maxCos 1) 2)))))
(+.f32 (-.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (log.f32 (/.f32 -1 ux))) (-.f32 (log.f32 (+.f32 1 (neg.f32 maxCos))) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(-.f32 (+.f32 (log.f32 (*.f32 -1 (-.f32 maxCos 1))) (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (+.f32 (*.f32 1/3 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 3) (pow.f32 ux 3)))) (/.f32 1 (*.f32 (-.f32 maxCos 1) ux))))) (*.f32 1/2 (/.f32 1 (*.f32 (pow.f32 (-.f32 maxCos 1) 2) (pow.f32 ux 2)))))
(-.f32 (+.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1)))) (+.f32 (/.f32 1 (*.f32 ux (-.f32 maxCos 1))) (/.f32 1/3 (*.f32 (pow.f32 ux 3) (pow.f32 (-.f32 maxCos 1) 3))))) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2))))
(-.f32 (+.f32 (+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (/.f32 (/.f32 1/3 (pow.f32 ux 3)) (pow.f32 (-.f32 maxCos 1) 3))) (-.f32 (log.f32 (+.f32 (neg.f32 maxCos) 1)) (log.f32 (/.f32 -1 ux)))) (/.f32 1/2 (*.f32 ux (*.f32 ux (pow.f32 (-.f32 maxCos 1) 2)))))
(+.f32 (+.f32 (/.f32 (/.f32 1 (-.f32 maxCos 1)) ux) (-.f32 (/.f32 (/.f32 1/3 (pow.f32 ux 3)) (pow.f32 (-.f32 maxCos 1) 3)) (log.f32 (/.f32 -1 ux)))) (-.f32 (log.f32 (+.f32 1 (neg.f32 maxCos))) (/.f32 1/2 (*.f32 (*.f32 ux ux) (pow.f32 (-.f32 maxCos 1) 2)))))
(*.f32 -1 ux)
(neg.f32 ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 maxCos ux)
(*.f32 ux maxCos)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 maxCos ux)
(*.f32 ux maxCos)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) (*.f32 maxCos ux))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(*.f32 (-.f32 maxCos 1) ux)
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (*.f32 -1 ux) 1)
(fma.f32 -1 ux 1)
(-.f32 1 ux)
(+.f32 (*.f32 -1 ux) (+.f32 1 (*.f32 maxCos ux)))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(+.f32 (*.f32 -1 ux) (+.f32 1 (+.f32 (*.f32 maxCos ux) (*.f32 (+.f32 (*.f32 1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (*.f32 -1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2)))) (*.f32 (pow.f32 maxCos 2) (+.f32 (*.f32 -1 ux) 1))))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(+.f32 (*.f32 (pow.f32 maxCos 3) (*.f32 (+.f32 (*.f32 1/3 (/.f32 (pow.f32 ux 3) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))) (+.f32 (*.f32 1/6 (/.f32 (pow.f32 ux 3) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))) (*.f32 -1/2 (/.f32 (pow.f32 ux 3) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3))))) (+.f32 (*.f32 -1 ux) 1))) (+.f32 (*.f32 -1 ux) (+.f32 1 (+.f32 (*.f32 maxCos ux) (*.f32 (+.f32 (*.f32 1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2))) (*.f32 -1/2 (/.f32 (pow.f32 ux 2) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2)))) (*.f32 (pow.f32 maxCos 2) (+.f32 (*.f32 -1 ux) 1)))))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))
(*.f32 ux maxCos)
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) maxCos))
(+.f32 (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))) (/.f32 (+.f32 (/.f32 1 ux) -1) (/.f32 maxCos (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))))))
(fma.f32 (exp.f32 (log.f32 maxCos)) ux (*.f32 (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos) (*.f32 ux (exp.f32 (log.f32 maxCos)))))
(*.f32 (+.f32 (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos) 1) (*.f32 ux maxCos))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (+.f32 (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) maxCos) (/.f32 (*.f32 (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (pow.f32 (-.f32 (/.f32 1 ux) 1) 2))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) (pow.f32 maxCos 2))))
(+.f32 (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))) (+.f32 (/.f32 (+.f32 (/.f32 1 ux) -1) (/.f32 maxCos (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))))) (/.f32 (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))) (/.f32 (*.f32 maxCos maxCos) (fma.f32 -1/2 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 2) (*.f32 ux ux)) (*.f32 1/2 (pow.f32 (+.f32 (/.f32 1 ux) -1) 2)))))))
(+.f32 (fma.f32 (exp.f32 (log.f32 maxCos)) ux (*.f32 (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos) (*.f32 ux (exp.f32 (log.f32 maxCos))))) (*.f32 (/.f32 (*.f32 ux (exp.f32 (log.f32 maxCos))) maxCos) (/.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 ux ux)) (*.f32 1/2 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2))) maxCos)))
(+.f32 (*.f32 (+.f32 (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos) 1) (*.f32 ux maxCos)) 0)
(+.f32 (/.f32 (*.f32 (+.f32 (*.f32 -1/2 (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2)) (pow.f32 ux 2))) (+.f32 (*.f32 1/6 (pow.f32 (-.f32 (/.f32 1 ux) 1) 3)) (*.f32 1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) (pow.f32 maxCos 3)) (+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (+.f32 (/.f32 (*.f32 (-.f32 (/.f32 1 ux) 1) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux)))) maxCos) (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 1 maxCos))) (log.f32 ux))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (pow.f32 (-.f32 (/.f32 1 ux) 1) 2)))) (pow.f32 maxCos 2)))))
(+.f32 (/.f32 (fma.f32 -1/2 (/.f32 (+.f32 (/.f32 1 ux) -1) (/.f32 (*.f32 ux ux) (pow.f32 (fma.f32 -1 ux 1) 2))) (fma.f32 1/6 (pow.f32 (+.f32 (/.f32 1 ux) -1) 3) (*.f32 1/3 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 3) (pow.f32 ux 3))))) (/.f32 (pow.f32 maxCos 3) (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))))) (+.f32 (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))) (+.f32 (/.f32 (+.f32 (/.f32 1 ux) -1) (/.f32 maxCos (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))))) (/.f32 (exp.f32 (fma.f32 -1 (neg.f32 (log.f32 maxCos)) (log.f32 ux))) (/.f32 (*.f32 maxCos maxCos) (fma.f32 -1/2 (/.f32 (pow.f32 (fma.f32 -1 ux 1) 2) (*.f32 ux ux)) (*.f32 1/2 (pow.f32 (+.f32 (/.f32 1 ux) -1) 2))))))))
(+.f32 (*.f32 (/.f32 (fma.f32 -1/2 (*.f32 (/.f32 (pow.f32 (-.f32 1 ux) 2) ux) (/.f32 (+.f32 -1 (/.f32 1 ux)) ux)) (fma.f32 1/3 (/.f32 (pow.f32 (-.f32 1 ux) 3) (pow.f32 ux 3)) (*.f32 1/6 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 3)))) (pow.f32 maxCos 3)) (*.f32 ux (exp.f32 (log.f32 maxCos)))) (+.f32 (fma.f32 (exp.f32 (log.f32 maxCos)) ux (*.f32 (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos) (*.f32 ux (exp.f32 (log.f32 maxCos))))) (*.f32 (/.f32 (*.f32 ux (exp.f32 (log.f32 maxCos))) maxCos) (/.f32 (fma.f32 -1/2 (/.f32 (pow.f32 (-.f32 1 ux) 2) (*.f32 ux ux)) (*.f32 1/2 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 2))) maxCos))))
(+.f32 (/.f32 (fma.f32 -1/2 (*.f32 (/.f32 (pow.f32 (-.f32 1 ux) 2) ux) (/.f32 (+.f32 -1 (/.f32 1 ux)) ux)) (+.f32 (*.f32 1/2 (pow.f32 (+.f32 -1 (/.f32 1 ux)) 3)) 0)) (/.f32 (pow.f32 maxCos 3) (*.f32 ux maxCos))) (+.f32 (*.f32 (+.f32 (/.f32 (+.f32 -1 (/.f32 1 ux)) maxCos) 1) (*.f32 ux maxCos)) 0))
(exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))
(exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux))))
(*.f32 (neg.f32 ux) (pow.f32 (/.f32 -1 maxCos) -1))
(/.f32 (neg.f32 ux) (/.f32 -1 maxCos))
(+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1 ux) 1)) (*.f32 maxCos ux)) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))))
(+.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))) (/.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))) (/.f32 maxCos (/.f32 (fma.f32 -1 ux 1) ux))))
(fma.f32 (pow.f32 (/.f32 -1 maxCos) -1) (neg.f32 ux) (*.f32 (/.f32 (pow.f32 (/.f32 -1 maxCos) -1) (/.f32 maxCos (neg.f32 ux))) (/.f32 (-.f32 1 ux) ux)))
(fma.f32 (/.f32 (/.f32 (neg.f32 ux) (/.f32 -1 maxCos)) maxCos) (+.f32 -1 (/.f32 1 ux)) (/.f32 (neg.f32 ux) (/.f32 -1 maxCos)))
(+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))))) (pow.f32 maxCos 2)) (+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1 ux) 1)) (*.f32 maxCos ux)) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))))
(+.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))) (/.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))) (/.f32 maxCos (/.f32 (fma.f32 -1 ux 1) ux))))
(fma.f32 (pow.f32 (/.f32 -1 maxCos) -1) (neg.f32 ux) (*.f32 (/.f32 (pow.f32 (/.f32 -1 maxCos) -1) (/.f32 maxCos (neg.f32 ux))) (/.f32 (-.f32 1 ux) ux)))
(fma.f32 (/.f32 (/.f32 (neg.f32 ux) (/.f32 -1 maxCos)) maxCos) (+.f32 -1 (/.f32 1 ux)) (/.f32 (neg.f32 ux) (/.f32 -1 maxCos)))
(+.f32 (*.f32 -1 (/.f32 (*.f32 (+.f32 (*.f32 -1/3 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))) (+.f32 (*.f32 1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))) (*.f32 -1/6 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 3) (pow.f32 ux 3))))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))) (pow.f32 maxCos 3))) (+.f32 (/.f32 (*.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))) (+.f32 (*.f32 -1 ux) 1)) (*.f32 maxCos ux)) (+.f32 (/.f32 (*.f32 (+.f32 (*.f32 -1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2))) (*.f32 1/2 (/.f32 (pow.f32 (+.f32 (*.f32 -1 ux) 1) 2) (pow.f32 ux 2)))) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux))))) (pow.f32 maxCos 2)) (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 maxCos))) (log.f32 (*.f32 -1 ux)))))))
(+.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))) (/.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 maxCos)) (log.f32 (neg.f32 ux)))) (/.f32 maxCos (/.f32 (fma.f32 -1 ux 1) ux))))
(fma.f32 (pow.f32 (/.f32 -1 maxCos) -1) (neg.f32 ux) (*.f32 (/.f32 (pow.f32 (/.f32 -1 maxCos) -1) (/.f32 maxCos (neg.f32 ux))) (/.f32 (-.f32 1 ux) ux)))
(fma.f32 (/.f32 (/.f32 (neg.f32 ux) (/.f32 -1 maxCos)) maxCos) (+.f32 -1 (/.f32 1 ux)) (/.f32 (neg.f32 ux) (/.f32 -1 maxCos)))
1
(+.f32 1 (*.f32 (-.f32 maxCos 1) ux))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(+.f32 1 (+.f32 (*.f32 (-.f32 maxCos 1) ux) (*.f32 (+.f32 (*.f32 1/2 (pow.f32 (-.f32 maxCos 1) 2)) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 2))) (pow.f32 ux 2))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(+.f32 1 (+.f32 (*.f32 (+.f32 (*.f32 1/6 (pow.f32 (-.f32 maxCos 1) 3)) (+.f32 (*.f32 1/3 (pow.f32 (-.f32 maxCos 1) 3)) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 3)))) (pow.f32 ux 3)) (+.f32 (*.f32 (-.f32 maxCos 1) ux) (*.f32 (+.f32 (*.f32 1/2 (pow.f32 (-.f32 maxCos 1) 2)) (*.f32 -1/2 (pow.f32 (-.f32 maxCos 1) 2))) (pow.f32 ux 2)))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux)))))
(*.f32 ux (-.f32 maxCos 1))
(-.f32 (*.f32 ux maxCos) ux)
(+.f32 (/.f32 (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))) (*.f32 (-.f32 maxCos 1) ux)) (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(+.f32 (/.f32 (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))) (*.f32 (-.f32 maxCos 1) ux)) (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(+.f32 (/.f32 (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))) (*.f32 (-.f32 maxCos 1) ux)) (exp.f32 (+.f32 (log.f32 (-.f32 maxCos 1)) (*.f32 -1 (log.f32 (/.f32 1 ux))))))
(+.f32 (fma.f32 -1 ux 1) (*.f32 ux maxCos))
(-.f32 (fma.f32 ux maxCos 1) ux)
(fma.f32 ux (-.f32 maxCos 1) 1)
(exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1)))))
(exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1)))))
(*.f32 (pow.f32 (/.f32 -1 ux) -1) (+.f32 (neg.f32 maxCos) 1))
(/.f32 (+.f32 1 (neg.f32 maxCos)) (/.f32 -1 ux))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (*.f32 (-.f32 maxCos 1) ux)))
(+.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))) (*.f32 ux (-.f32 maxCos 1))))
(fma.f32 (pow.f32 (/.f32 -1 ux) -1) (+.f32 (neg.f32 maxCos) 1) (*.f32 (/.f32 (pow.f32 (/.f32 -1 ux) -1) ux) (/.f32 (+.f32 (neg.f32 maxCos) 1) (-.f32 maxCos 1))))
(+.f32 (/.f32 (+.f32 1 (neg.f32 maxCos)) (/.f32 -1 ux)) (*.f32 (/.f32 (/.f32 1 (/.f32 -1 ux)) ux) -1))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (*.f32 (-.f32 maxCos 1) ux)))
(+.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))) (*.f32 ux (-.f32 maxCos 1))))
(fma.f32 (pow.f32 (/.f32 -1 ux) -1) (+.f32 (neg.f32 maxCos) 1) (*.f32 (/.f32 (pow.f32 (/.f32 -1 ux) -1) ux) (/.f32 (+.f32 (neg.f32 maxCos) 1) (-.f32 maxCos 1))))
(+.f32 (/.f32 (+.f32 1 (neg.f32 maxCos)) (/.f32 -1 ux)) (*.f32 (/.f32 (/.f32 1 (/.f32 -1 ux)) ux) -1))
(+.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (+.f32 (*.f32 -1 (log.f32 (/.f32 -1 ux))) (log.f32 (*.f32 -1 (-.f32 maxCos 1))))) (*.f32 (-.f32 maxCos 1) ux)))
(+.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))) (/.f32 (exp.f32 (fma.f32 -1 (log.f32 (/.f32 -1 ux)) (log.f32 (neg.f32 (-.f32 maxCos 1))))) (*.f32 ux (-.f32 maxCos 1))))
(fma.f32 (pow.f32 (/.f32 -1 ux) -1) (+.f32 (neg.f32 maxCos) 1) (*.f32 (/.f32 (pow.f32 (/.f32 -1 ux) -1) ux) (/.f32 (+.f32 (neg.f32 maxCos) 1) (-.f32 maxCos 1))))
(+.f32 (/.f32 (+.f32 1 (neg.f32 maxCos)) (/.f32 -1 ux)) (*.f32 (/.f32 (/.f32 1 (/.f32 -1 ux)) ux) -1))

prune100.0ms (4.3%)

Pruning

2 alts after pruning (0 fresh and 2 done)

PrunedKeptTotal
New1460146
Fresh000
Picked011
Done011
Total1462148
Error
0b
Counts
148 → 2
Alt Table
StatusErrorProgram
0.0b
(+.f32 (-.f32 1 ux) (*.f32 ux maxCos))
0.0b
(exp.f32 (log1p.f32 (*.f32 (+.f32 maxCos -1) ux)))
Compiler

Compiled 3037 to 2324 computations (23.5% saved)

regimes81.0ms (3.5%)

Accuracy

Total 0.0b remaining (56.1%)

Threshold costs 0.0b (56.1%)

Counts
36 → 1
Compiler

Compiled 282 to 192 computations (31.9% saved)

simplify2.0ms (0.1%)

Algorithm
egg-herbie
Rules
+-commutative_binary32
sub-neg_binary32
1-exp_binary32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
068
1118
2128
Stop Event
saturated
Calls
Call 1
Inputs
(fma.f32 ux (-.f32 maxCos 1) 1)
Outputs
(fma.f32 ux (-.f32 maxCos 1) 1)
(fma.f32 ux (+.f32 maxCos -1) 1)

end34.0ms (1.5%)

Stop Event
done
Compiler

Compiled 38 to 29 computations (23.7% saved)

Profiling

Loading profile data...