tanhf (example 3.4)

Time bar (total: 5.4s)

analyze158.0ms (2.9%)

Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%100%0%0%0%0%0
0%0%100%0%0%0%0%1
0%0%100%0%0%0%0%2
25%25%75%0%0%0%0%3
37.5%37.5%62.5%0%0%0%0%4
43.8%43.7%56.2%0%0%0%0%5
46.9%46.9%53.1%0%0%0%0%6
48.4%48.4%51.5%0%0%0%0%7
49.2%49.2%50.8%0%0%0%0%8
49.6%49.6%50.4%0%0%0%0%9
49.8%49.8%50.2%0%0%0%0%10
49.9%49.9%50.1%0%0%0%0%11
50%49.9%50%0%0%0%0%12
Compiler

Compiled 9 to 7 computations (22.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 76.0ms
Operation ival-cos, time spent: 24.0ms, 32.0% of total-time
Operation ival-div, time spent: 18.0ms, 24.0% of total-time
Operation ival-sin, time spent: 18.0ms, 24.0% of total-time
Operation ival-sub, time spent: 13.0ms, 17.0% of total-time
Operation const, time spent: 3.0ms, 4.0% of total-time

sample4.0s (73.6%)

Results
764.0ms4590×256valid
2.2s2042×2048valid
428.0ms1039×1024valid
92.0ms520×512valid
46.0ms65×4096valid
Precisions
Click to see histograms. Total time spent on operations: 2.9s
Operation ival-sin, time spent: 1.5s, 53.0% of total-time
Operation ival-cos, time spent: 909.0ms, 32.0% of total-time
Operation ival-sub, time spent: 251.0ms, 9.0% of total-time
Operation ival-div, time spent: 154.0ms, 5.0% of total-time
Operation const, time spent: 25.0ms, 1.0% of total-time
Bogosity

preprocess522.0ms (9.6%)

Algorithm
egg-herbie
Rules
199×fma-define
83×fma-neg
47×times-frac
47×div-sub
37×distribute-rgt-in
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
681(6972714.758005748)0-(-.f64 #s(literal 1 binary64) (cos.f64 x))
490-3(4.951964052207256e-156)(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
00-0-x
00-0-(sin.f64 x)
00-0-#s(literal 1 binary64)
00-0-(cos.f64 x)
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01760
14660
28556
319156
447056
581556
698156
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 (neg.f64 x))) (sin.f64 (neg.f64 x)))
(neg.f64 (/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 (neg.f64 x))) (sin.f64 (neg.f64 x))))
Outputs
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(tan.f64 (*.f64 x #s(literal 1/2 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(tan.f64 (*.f64 x #s(literal 1/2 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 (neg.f64 x))) (sin.f64 (neg.f64 x)))
(tan.f64 (/.f64 (neg.f64 x) #s(literal 2 binary64)))
(neg.f64 (tan.f64 (/.f64 x #s(literal 2 binary64))))
(tan.f64 (*.f64 x #s(literal -1/2 binary64)))
(neg.f64 (/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 (neg.f64 x))) (sin.f64 (neg.f64 x))))
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(tan.f64 (*.f64 x #s(literal 1/2 binary64)))
Symmetry

(negabs x)

Results
63.0ms336×256valid
94.0ms96×2048valid
18.0ms50×1024valid
6.0ms28×512valid
2.0ms4096valid
Compiler

Compiled 46 to 26 computations (43.5% saved)

Precisions
Click to see histograms. Total time spent on operations: 133.0ms
Operation ival-sin, time spent: 64.0ms, 48.0% of total-time
Operation ival-cos, time spent: 47.0ms, 35.0% of total-time
Operation ival-sub, time spent: 12.0ms, 9.0% of total-time
Operation ival-div, time spent: 8.0ms, 6.0% of total-time
Operation const, time spent: 3.0ms, 2.0% of total-time

eval0.0ms (0%)

Compiler

Compiled 9 to 7 computations (22.2% saved)

prune1.0ms (0%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(tan.f64 (/.f64 x #s(literal 2 binary64)))
Compiler

Compiled 5 to 4 computations (20% saved)

localize43.0ms (0.8%)

Localize:

Found 1 expressions with local error:

NewAccuracyProgram
100.0%
(tan.f64 (/.f64 x #s(literal 2 binary64)))
Results
29.0ms256×256valid
Compiler

Compiled 11 to 8 computations (27.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 15.0ms
Operation ival-tan, time spent: 8.0ms, 54.0% of total-time
Operation ival-div, time spent: 6.0ms, 41.0% of total-time
Operation const, time spent: 1.0ms, 7.0% of total-time

series2.0ms (0%)

Counts
1 → 12
Calls
Call 1
Inputs
#<alt (tan.f64 (/.f64 x #s(literal 2 binary64)))>
Outputs
#<alt (*.f64 #s(literal 1/2 binary64) x)>
#<alt (*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)))))>
#<alt (*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 2 binary64)))))))>
#<alt (*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 2 binary64)))))))))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
Calls

3 calls:

TimeVariablePointExpression
1.0ms
x
@inf
(tan (/ x 2))
1.0ms
x
@-inf
(tan (/ x 2))
1.0ms
x
@0
(tan (/ x 2))

rewrite172.0ms (3.2%)

Algorithm
batch-egg-rewrite
Rules
549×frac-times
314×log1p-expm1-u
314×expm1-log1p-u
304×add-exp-log
295×add-log-exp
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0914
17614
287414
Stop Event
node limit
Counts
1 → 46
Calls
Call 1
Inputs
(tan.f64 (/.f64 x #s(literal 2 binary64)))
Outputs
(+.f64 #s(literal 0 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(-.f64 (+.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (log.f64 (E.f64)))
(*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/4 binary64)) (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3/2 binary64))))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1/3 binary64)) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (pow.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64)) #s(literal 1/3 binary64)) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (cbrt.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3/2 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/4 binary64)))
(*.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 5 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (-.f64 (sin.f64 (+.f64 #s(literal 1 binary64) x)) (sin.f64 #s(literal 1 binary64))) (+.f64 (cos.f64 (+.f64 #s(literal 1 binary64) x)) (cos.f64 #s(literal 1 binary64))))
(/.f64 (cbrt.f64 (*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sqrt.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sqrt.f64 (*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 3 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) #s(literal 1/3 binary64))
(pow.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))
(pow.f64 (E.f64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(neg.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)))
(fabs.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(log.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)))
(expm1.f64 (log1p.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(log1p.f64 (expm1.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(exp.f64 (*.f64 (*.f64 #s(literal 3 binary64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 1/3 binary64)))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)))

simplify107.0ms (2%)

Algorithm
egg-herbie
Rules
868×prod-exp
561×sub-neg
304×fma-neg
285×fma-define
261×associate-+l+
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01531783
12641727
26951709
321651709
436991709
565551709
Stop Event
node limit
Counts
58 → 77
Calls
Call 1
Inputs
(*.f64 #s(literal 1/2 binary64) x)
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 2 binary64)))))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 2 binary64)))))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(+.f64 #s(literal 0 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(-.f64 (+.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (log.f64 (E.f64)))
(*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/4 binary64)) (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3/2 binary64))))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1/3 binary64)) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (pow.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64)) #s(literal 1/3 binary64)) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (cbrt.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3/2 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/4 binary64)))
(*.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 5 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 #s(literal 1 binary64) (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (-.f64 (sin.f64 (+.f64 #s(literal 1 binary64) x)) (sin.f64 #s(literal 1 binary64))) (+.f64 (cos.f64 (+.f64 #s(literal 1 binary64) x)) (cos.f64 #s(literal 1 binary64))))
(/.f64 (cbrt.f64 (*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sqrt.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sqrt.f64 (*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 3 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) #s(literal 1/3 binary64))
(pow.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))
(pow.f64 (E.f64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(neg.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)))
(fabs.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(log.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)))
(expm1.f64 (log1p.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(log1p.f64 (expm1.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(exp.f64 (*.f64 (*.f64 #s(literal 3 binary64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 1/3 binary64)))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)))
Outputs
(*.f64 #s(literal 1/2 binary64) x)
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)))))
(*.f64 x (fma.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)) #s(literal 1/2 binary64)))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 2 binary64)))))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 1/240 binary64))))))
(*.f64 x (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 1/240 binary64) #s(literal 1/24 binary64)) #s(literal 1/2 binary64)))
(*.f64 x (fma.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)) (fma.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 2 binary64)))))))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 17/40320 binary64))))))))
(*.f64 x (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 17/40320 binary64) #s(literal 1/240 binary64)) #s(literal 1/24 binary64)) #s(literal 1/2 binary64)))
(*.f64 x (fma.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)) (fma.f64 (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 17/40320 binary64) #s(literal 1/240 binary64)) (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(+.f64 #s(literal 0 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(*.f64 #s(literal 2 binary64) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))))))
(-.f64 (+.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (log.f64 (E.f64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/4 binary64)) (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3/2 binary64))))
(*.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1/4 binary64)) (sqrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3/2 binary64))))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1/3 binary64)) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (cbrt.f64 (pow.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 4 binary64)) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 8 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64)) #s(literal 1/3 binary64)) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (cbrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 5/2 binary64))) (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1/6 binary64)))
(*.f64 (cbrt.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (cbrt.f64 (pow.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 4 binary64)) #s(literal 2 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (cbrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 8 binary64))) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (cbrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 5/2 binary64))) (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1/6 binary64)))
(*.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3/2 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/4 binary64)))
(*.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1/4 binary64)) (sqrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3/2 binary64))))
(*.f64 (sqrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 5 binary64))) (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1/6 binary64)))
(*.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 1/6 binary64)) (sqrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 5 binary64))))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (neg.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 (neg.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 #s(literal 1 binary64) (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (-.f64 (sin.f64 (+.f64 #s(literal 1 binary64) x)) (sin.f64 #s(literal 1 binary64))) (+.f64 (cos.f64 (+.f64 #s(literal 1 binary64) x)) (cos.f64 #s(literal 1 binary64))))
(tan.f64 (/.f64 (-.f64 (+.f64 x #s(literal 1 binary64)) #s(literal 1 binary64)) #s(literal 2 binary64)))
(tan.f64 (/.f64 (+.f64 x #s(literal 0 binary64)) #s(literal 2 binary64)))
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(/.f64 (cbrt.f64 (*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (cbrt.f64 (*.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 2 binary64)))) (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 (sqrt.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sqrt.f64 (*.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) (sin.f64 (*.f64 #s(literal 1/2 binary64) x)))) (sqrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 (sqrt.f64 (*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sqrt.f64 (*.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) (sin.f64 (*.f64 #s(literal 1/2 binary64) x)))) (sqrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))))
(pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 3 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) #s(literal 1/3 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (E.f64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(neg.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(neg.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))
(sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(fabs.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(log.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(expm1.f64 (log1p.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(log1p.f64 (expm1.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (*.f64 #s(literal 3 binary64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 1/3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))

eval25.0ms (0.5%)

Compiler

Compiled 885 to 740 computations (16.4% saved)

prune9.0ms (0.2%)

Pruning

3 alts after pruning (2 fresh and 1 done)

PrunedKeptTotal
New75277
Fresh000
Picked011
Done000
Total75378
Accuracy
100.0%
Counts
78 → 3
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.8%
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
44.0%
(*.f64 #s(literal 1/2 binary64) x)
100.0%
(tan.f64 (/.f64 x #s(literal 2 binary64)))
Compiler

Compiled 19 to 15 computations (21.1% saved)

localize87.0ms (1.6%)

Localize:

Found 1 expressions with local error:

NewAccuracyProgram
99.8%
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
Results
68.0ms256×256valid
Compiler

Compiled 29 to 21 computations (27.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 45.0ms
Operation ival-sin, time spent: 15.0ms, 33.0% of total-time
Operation ival-cos, time spent: 14.0ms, 31.0% of total-time
Operation ival-mult, time spent: 12.0ms, 27.0% of total-time
Operation ival-div, time spent: 2.0ms, 4.0% of total-time
Operation const, time spent: 2.0ms, 4.0% of total-time

series1.0ms (0%)

Counts
1 → 12
Calls
Call 1
Inputs
#<alt (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))>
Outputs
#<alt (*.f64 #s(literal 1/2 binary64) x)>
#<alt (*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)))))>
#<alt (*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 2 binary64)))))))>
#<alt (*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 2 binary64)))))))))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
#<alt (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))>
Calls

3 calls:

TimeVariablePointExpression
0.0ms
x
@0
(/ (sin (* x 1/2)) (cos (* x 1/2)))
0.0ms
x
@inf
(/ (sin (* x 1/2)) (cos (* x 1/2)))
0.0ms
x
@-inf
(/ (sin (* x 1/2)) (cos (* x 1/2)))

rewrite75.0ms (1.4%)

Algorithm
batch-egg-rewrite
Rules
520×log1p-expm1-u
520×expm1-log1p-u
493×unpow-prod-down
468×pow1
292×log-prod
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01114
111114
2139214
Stop Event
node limit
Counts
1 → 68
Calls
Call 1
Inputs
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
Outputs
(+.f64 #s(literal 0 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(-.f64 (+.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64))
(*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (log.f64 (E.f64)))
(*.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (*.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (neg.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (/.f64 #s(literal 1 binary64) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) #s(literal 1 binary64)) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1/3 binary64)) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 3 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)) (pow.f64 (sqrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(*.f64 (pow.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64)) (pow.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64)))
(*.f64 (pow.f64 (*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1/3 binary64)) (cbrt.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal -1 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 3 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) #s(literal 1/3 binary64))
(pow.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))
(pow.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64))
(pow.f64 (E.f64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(pow.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64))
(pow.f64 (/.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) #s(literal -1 binary64))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(neg.f64 (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(neg.f64 (/.f64 (neg.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)))
(log.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)))
(cbrt.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))))
(expm1.f64 (log1p.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(log1p.f64 (expm1.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(exp.f64 (*.f64 (*.f64 #s(literal 3 binary64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 1/3 binary64)))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (neg.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(tan.f64 (*.f64 x #s(literal 1/2 binary64)))

simplify83.0ms (1.5%)

Algorithm
egg-herbie
Rules
435×associate-/r*
396×associate-*r*
328×associate-*l*
268×fma-define
259×associate-/r/
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
02252616
14522567
211312543
340302525
Stop Event
node limit
Counts
80 → 110
Calls
Call 1
Inputs
(*.f64 #s(literal 1/2 binary64) x)
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 2 binary64)))))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 2 binary64)))))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(+.f64 #s(literal 0 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(-.f64 (+.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64))
(*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (log.f64 (E.f64)))
(*.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (*.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (neg.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (/.f64 #s(literal 1 binary64) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) #s(literal 1 binary64)) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1/3 binary64)) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 3 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)) (pow.f64 (sqrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(*.f64 (pow.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64)) (pow.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64)))
(*.f64 (pow.f64 (*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1/3 binary64)) (cbrt.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal -1 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 3 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) #s(literal 1/3 binary64))
(pow.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))
(pow.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64))
(pow.f64 (E.f64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(pow.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64))
(pow.f64 (/.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) #s(literal -1 binary64))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(neg.f64 (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(neg.f64 (/.f64 (neg.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)))
(log.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)))
(cbrt.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))))
(expm1.f64 (log1p.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(log1p.f64 (expm1.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(exp.f64 (*.f64 (*.f64 #s(literal 3 binary64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 1/3 binary64)))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)))
(exp.f64 (*.f64 (neg.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(tan.f64 (*.f64 x #s(literal 1/2 binary64)))
Outputs
(*.f64 #s(literal 1/2 binary64) x)
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)))))
(*.f64 x (fma.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)) #s(literal 1/2 binary64)))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 2 binary64)))))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 1/240 binary64))))))
(*.f64 x (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 1/240 binary64) #s(literal 1/24 binary64)) #s(literal 1/2 binary64)))
(*.f64 x (fma.f64 #s(literal 1/24 binary64) (pow.f64 x #s(literal 2 binary64)) (fma.f64 #s(literal 1/240 binary64) (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 2 binary64)))))))))
(*.f64 x (+.f64 #s(literal 1/2 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/24 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) (+.f64 #s(literal 1/240 binary64) (*.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 17/40320 binary64))))))))
(*.f64 x (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 17/40320 binary64) #s(literal 1/240 binary64)) #s(literal 1/24 binary64)) #s(literal 1/2 binary64)))
(*.f64 x (fma.f64 (pow.f64 x #s(literal 2 binary64)) (fma.f64 (pow.f64 x #s(literal 2 binary64)) #s(literal 1/240 binary64) (fma.f64 #s(literal 17/40320 binary64) (pow.f64 x #s(literal 4 binary64)) #s(literal 1/24 binary64))) #s(literal 1/2 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(+.f64 #s(literal 0 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(+.f64 (log.f64 (pow.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))) (log.f64 (cbrt.f64 (exp.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))))))
(+.f64 (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))))
(*.f64 #s(literal 2 binary64) (log.f64 (sqrt.f64 (exp.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))))))
(-.f64 (+.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (log.f64 (E.f64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (*.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (*.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (neg.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (/.f64 #s(literal 1 binary64) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (/.f64 #s(literal 1 binary64) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)) (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)) (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)) (/.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) (sin.f64 (*.f64 #s(literal 1/2 binary64) x))))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)) (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)) (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)) (/.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) (sin.f64 (*.f64 #s(literal 1/2 binary64) x))))
(*.f64 (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (pow.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64)) (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (sqrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (/.f64 (pow.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64)) (sqrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(*.f64 (pow.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64)) (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (sqrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (/.f64 (pow.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64)) (sqrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) #s(literal 1 binary64)) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 2 binary64))))
(*.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 2 binary64)) (/.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 2 binary64))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal -2 binary64)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))) (/.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 #s(literal 1 binary64) #s(literal 1/3 binary64)) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 3 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (sqrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)) (pow.f64 (sqrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(*.f64 (pow.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64)) (pow.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64)))
(*.f64 (cbrt.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3 binary64)))) (cbrt.f64 (sqrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3 binary64)))))
(*.f64 (cbrt.f64 (pow.f64 (sqrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 3 binary64))) (cbrt.f64 (pow.f64 (sqrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 3 binary64))))
(*.f64 (pow.f64 (*.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1/3 binary64)) (cbrt.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (*.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 2 binary64)))) (cbrt.f64 (/.f64 #s(literal 1 binary64) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (pow.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) (cbrt.f64 (pow.f64 (*.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))))
(*.f64 (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) (cbrt.f64 (pow.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 4 binary64)) #s(literal 2 binary64))))
(*.f64 (cbrt.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) (cbrt.f64 (pow.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 8 binary64))))
(*.f64 (pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 5/2 binary64)) #s(literal 1/3 binary64)) (cbrt.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(*.f64 (cbrt.f64 (pow.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 5/2 binary64))) (cbrt.f64 (sqrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)) #s(literal -1 binary64)) (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(*.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) (/.f64 #s(literal 1 binary64) (pow.f64 (cbrt.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))))
(/.f64 (cbrt.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))) (pow.f64 (cbrt.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64)))
(*.f64 (pow.f64 (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -2 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (/.f64 #s(literal 1 binary64) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64))) (/.f64 #s(literal 1 binary64) (/.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))))))
(*.f64 (/.f64 #s(literal 1 binary64) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64))) (/.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) (cos.f64 (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 (/.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal -2 binary64)))
(*.f64 (pow.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal -1/2 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(*.f64 (/.f64 #s(literal 1 binary64) (pow.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64))) (/.f64 #s(literal 1 binary64) (/.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) (sqrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))))))
(*.f64 (/.f64 #s(literal 1 binary64) (pow.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64))) (/.f64 (sqrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) (cos.f64 (*.f64 #s(literal 1/2 binary64) x))))
(/.f64 (/.f64 (sqrt.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x))) (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) (pow.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal -1/2 binary64)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (/.f64 (pow.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64)) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)) (pow.f64 (/.f64 (cbrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (pow.f64 (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (cbrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(*.f64 (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)) (pow.f64 (/.f64 (sqrt.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64)))) (sqrt.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 3 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)) #s(literal 1/2 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) #s(literal 1/3 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 2 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal -1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (E.f64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))) #s(literal 1/3 binary64))
(cbrt.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3 binary64))))
(cbrt.f64 (pow.f64 (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 3 binary64)))
(pow.f64 (/.f64 (/.f64 #s(literal 1 binary64) (tan.f64 (*.f64 x #s(literal 1/2 binary64)))) #s(literal 1 binary64)) #s(literal -1 binary64))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (pow.f64 (cbrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))) #s(literal 2 binary64))) (cbrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))))
(pow.f64 (exp.f64 (sqrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x))))) (sqrt.f64 (log.f64 (tan.f64 (*.f64 #s(literal 1/2 binary64) x)))))
(neg.f64 (/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (neg.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(neg.f64 (/.f64 (neg.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64)))) (cos.f64 (*.f64 x #s(literal 1/2 binary64)))))
(/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x)))
(sqrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(log.f64 (exp.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(cbrt.f64 (pow.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(cbrt.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 x #s(literal 1/2 binary64))) #s(literal 3 binary64))))
(cbrt.f64 (/.f64 (pow.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3 binary64)) (pow.f64 (cos.f64 (*.f64 #s(literal 1/2 binary64) x)) #s(literal 3 binary64))))
(cbrt.f64 (pow.f64 (/.f64 (sin.f64 (*.f64 #s(literal 1/2 binary64) x)) (cos.f64 (*.f64 #s(literal 1/2 binary64) x))) #s(literal 3 binary64)))
(expm1.f64 (log1p.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(log1p.f64 (expm1.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64)))))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (log.f64 (cbrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (*.f64 #s(literal 3 binary64) (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 1/3 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (log.f64 (sqrt.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal 2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(exp.f64 (*.f64 (neg.f64 (log.f64 (tan.f64 (*.f64 x #s(literal 1/2 binary64))))) #s(literal -1 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))
(tan.f64 (*.f64 x #s(literal 1/2 binary64)))
(tan.f64 (*.f64 #s(literal 1/2 binary64) x))

eval41.0ms (0.8%)

Compiler

Compiled 1635 to 1385 computations (15.3% saved)

prune14.0ms (0.3%)

Pruning

3 alts after pruning (0 fresh and 3 done)

PrunedKeptTotal
New1100110
Fresh000
Picked022
Done011
Total1103113
Accuracy
100.0%
Counts
113 → 3
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.8%
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
44.0%
(*.f64 #s(literal 1/2 binary64) x)
100.0%
(tan.f64 (/.f64 x #s(literal 2 binary64)))
Compiler

Compiled 43 to 33 computations (23.3% saved)

regimes5.0ms (0.1%)

Counts
4 → 1
Calls
Call 1
Inputs
(*.f64 #s(literal 1/2 binary64) x)
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
(/.f64 (sin.f64 (*.f64 x #s(literal 1/2 binary64))) (cos.f64 (*.f64 x #s(literal 1/2 binary64))))
Outputs
(tan.f64 (/.f64 x #s(literal 2 binary64)))
Calls

2 calls:

3.0ms
x
2.0ms
(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
Results
AccuracySegmentsBranch
100.0%1x
100.0%1(/.f64 (-.f64 #s(literal 1 binary64) (cos.f64 x)) (sin.f64 x))
Compiler

Compiled 10 to 7 computations (30% saved)

regimes1.0ms (0%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
(*.f64 #s(literal 1/2 binary64) x)
Outputs
(*.f64 #s(literal 1/2 binary64) x)
Calls

1 calls:

1.0ms
x
Results
AccuracySegmentsBranch
44.0%1x
Compiler

Compiled 2 to 1 computations (50% saved)

simplify2.0ms (0%)

Algorithm
egg-herbie
Rules
*-commutative
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01124
11224
Stop Event
done
saturated
Calls
Call 1
Inputs
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(*.f64 #s(literal 1/2 binary64) x)
Outputs
(tan.f64 (/.f64 x #s(literal 2 binary64)))
(*.f64 #s(literal 1/2 binary64) x)
(*.f64 x #s(literal 1/2 binary64))
Compiler

Compiled 9 to 7 computations (22.2% saved)

soundness42.0ms (0.8%)

Rules
199×fma-define
83×fma-neg
47×times-frac
47×div-sub
37×distribute-rgt-in
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
01760
14660
28556
319156
447056
581556
698156
Stop Event
saturated
Compiler

Compiled 12 to 9 computations (25% saved)

end0.0ms (0%)

preprocess38.0ms (0.7%)

Remove

(negabs x)

Compiler

Compiled 72 to 56 computations (22.2% saved)

Profiling

Loading profile data...