math.exp on complex, real part

Time bar (total: 4.6s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage

analyze0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
100%99.9%0%0.1%0%0%0%1
Compiler

Compiled 7 to 7 computations (0% saved)

sample887.0ms (19.3%)

Memory
43.3MiB live, 1 074.2MiB allocated; 185ms collecting garbage
Samples
634.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 389.0ms
ival-cos: 190.0ms (48.8% of total)
ival-exp: 101.0ms (26% of total)
ival-mult: 88.0ms (22.6% of total)
ival-true: 6.0ms (1.5% of total)
ival-assert: 3.0ms (0.8% of total)
adjust: 2.0ms (0.5% of total)
Bogosity

explain131.0ms (2.8%)

Memory
-7.5MiB live, 102.3MiB allocated; 103ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
00-0-(*.f64 (exp.f64 re) (cos.f64 im))
00-0-(cos.f64 im)
00-0-re
00-0-(exp.f64 re)
00-0-im
Confusion
Predicted +Predicted -
+00
-0256
Precision
0/0
Recall
0/0
Confusion?
Predicted +Predicted MaybePredicted -
+000
-00256
Precision?
0/0
Recall?
0/0
Freqs
test
numberfreq
0256
Total Confusion?
Predicted +Predicted MaybePredicted -
+000
-001
Precision?
0/0
Recall?
0/0
Samples
61.0ms512×0valid
Compiler

Compiled 31 to 19 computations (38.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 18.0ms
ival-cos: 11.0ms (59.9% of total)
ival-exp: 4.0ms (21.8% of total)
ival-mult: 3.0ms (16.3% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess135.0ms (2.9%)

Memory
1.7MiB live, 187.8MiB allocated; 30ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01529
15129
213827
341727
4162427
055
085
1195
2395
3865
43255
525585
085295
Stop Event
iter limit
node limit
iter limit
node limit
Calls
Call 1
Inputs
(*.f64 (exp.f64 re) (cos.f64 im))
Outputs
(*.f64 (exp.f64 re) (cos.f64 im))
(*.f64 (cos.f64 im) (exp.f64 re))
Symmetry

(abs im)

Compiler

Compiled 5 to 5 computations (0% saved)

eval0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.8MiB live, 0.9MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
100.0%
(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

simplify110.0ms (2.4%)

Memory
11.1MiB live, 145.4MiB allocated; 23ms collecting garbage
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
cost-diff0
(cos.f64 im)
cost-diff0
(exp.f64 re)
cost-diff0
(*.f64 (exp.f64 re) (cos.f64 im))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0511
0811
11911
23911
38611
432511
5255811
0852911
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(*.f64 (exp.f64 re) (cos.f64 im))
(exp.f64 re)
re
(cos.f64 im)
im
Outputs
(*.f64 (exp.f64 re) (cos.f64 im))
(*.f64 (cos.f64 im) (exp.f64 re))
(exp.f64 re)
re
(cos.f64 im)
im

localize49.0ms (1.1%)

Memory
-13.6MiB live, 83.2MiB allocated; 37ms collecting garbage
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(exp.f64 re)
accuracy0.0
(cos.f64 im)
accuracy0.00390625
(*.f64 (exp.f64 re) (cos.f64 im))
Samples
44.0ms256×0valid
Compiler

Compiled 13 to 7 computations (46.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 21.0ms
ival-mult: 13.0ms (62.7% of total)
ival-cos: 6.0ms (28.9% of total)
ival-exp: 2.0ms (9.6% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series4.0ms (0.1%)

Memory
7.9MiB live, 7.9MiB allocated; 0ms collecting garbage
Counts
3 → 19
Calls
Call 1
Inputs
(*.f64 (exp.f64 re) (cos.f64 im))
(exp.f64 re)
(cos.f64 im)
Outputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) #s(hole binary64 (cos im)))
Calls

6 calls:

TimeVariablePointExpression
1.0ms
re
@inf
((* (exp re) (cos im)) (exp re) (cos im))
1.0ms
im
@0
((* (exp re) (cos im)) (exp re) (cos im))
1.0ms
re
@-inf
((* (exp re) (cos im)) (exp re) (cos im))
1.0ms
re
@0
((* (exp re) (cos im)) (exp re) (cos im))
0.0ms
im
@inf
((* (exp re) (cos im)) (exp re) (cos im))

simplify198.0ms (4.3%)

Memory
0.6MiB live, 232.9MiB allocated; 35ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
084264
1258253
2930249
34090245
08416225
Stop Event
iter limit
node limit
Counts
19 → 19
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) #s(hole binary64 (cos im)))
Outputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) (fma.f64 (cos.f64 im) re (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)) (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (cos im)) (*.f64 (cos.f64 im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (cos im)) (*.f64 (cos.f64 im) (exp.f64 re)))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (exp re) (exp.f64 re))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) (*.f64 (exp.f64 re) (fma.f64 (*.f64 #s(literal -1/2 binary64) im) im (fma.f64 (pow.f64 im #s(literal 4 binary64)) #s(literal 1/24 binary64) #s(literal 1 binary64)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (cos im)) (*.f64 (exp.f64 re) (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (pow.f64 im #s(literal 4 binary64)) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(literal 1 binary64))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) (fma.f64 (-.f64 (*.f64 #s(literal 1/24 binary64) (*.f64 im im)) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) (fma.f64 (fma.f64 (pow.f64 im #s(literal 4 binary64)) #s(literal -1/720 binary64) (-.f64 (*.f64 #s(literal 1/24 binary64) (*.f64 im im)) #s(literal 1/2 binary64))) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (cos im)))
#s(approx (cos im) (cos.f64 im))

rewrite57.0ms (1.2%)

Memory
-7.6MiB live, 39.2MiB allocated; 2ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
059
089
1199
2889
06579
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
3 → 49
Calls
Call 1
Inputs
(*.f64 (exp.f64 re) (cos.f64 im))
(exp.f64 re)
(cos.f64 im)
Outputs
(*.f64 (cos.f64 im) (exp.f64 re))
(*.f64 (exp.f64 re) (cos.f64 im))
(/.f64 (*.f64 (+.f64 (pow.f64 (sinh.f64 re) #s(literal 3 binary64)) (pow.f64 (cosh.f64 re) #s(literal 3 binary64))) (cos.f64 im)) (fma.f64 (sinh.f64 re) (-.f64 (sinh.f64 re) (cosh.f64 re)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64))))
(/.f64 (*.f64 (cos.f64 im) (+.f64 (pow.f64 (sinh.f64 re) #s(literal 3 binary64)) (pow.f64 (cosh.f64 re) #s(literal 3 binary64)))) (fma.f64 (sinh.f64 re) (-.f64 (sinh.f64 re) (cosh.f64 re)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64))))
(/.f64 (-.f64 (*.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (cosh.f64 re) (cos.f64 im))) (*.f64 (*.f64 (sinh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im)))) (-.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im))))
(/.f64 (+.f64 (pow.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 (sinh.f64 re) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (cosh.f64 re) (cos.f64 im)) (-.f64 (*.f64 (*.f64 (sinh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im))) (*.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im))))))
(/.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (exp.f64 (neg.f64 re)))
(fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (exp.f64 re) (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (exp.f64 re)))
(fma.f64 (sinh.f64 re) (cos.f64 im) (*.f64 (cosh.f64 re) (cos.f64 im)))
(fma.f64 (cosh.f64 re) (cos.f64 im) (*.f64 (sinh.f64 re) (cos.f64 im)))
(fma.f64 (cos.f64 im) (sinh.f64 re) (*.f64 (cosh.f64 re) (cos.f64 im)))
(fma.f64 (cos.f64 im) (cosh.f64 re) (*.f64 (sinh.f64 re) (cos.f64 im)))
(fma.f64 (exp.f64 re) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 (exp.f64 re) (*.f64 #s(literal 1 binary64) (cos.f64 im))))
(-.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (neg.f64 (sinh.f64 re)) (cos.f64 im)))
(-.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) (sinh.f64 re)))
(+.f64 (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (exp.f64 re)) (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (exp.f64 re)))
(+.f64 (*.f64 (exp.f64 re) (*.f64 #s(literal 0 binary64) (sin.f64 im))) (*.f64 (exp.f64 re) (*.f64 #s(literal 1 binary64) (cos.f64 im))))
(+.f64 (*.f64 (sinh.f64 re) (cos.f64 im)) (*.f64 (cosh.f64 re) (cos.f64 im)))
(+.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im)))
(/.f64 (-.f64 (pow.f64 (sinh.f64 re) #s(literal 2 binary64)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64))) (-.f64 (sinh.f64 re) (cosh.f64 re)))
(/.f64 (fma.f64 #s(literal 2 binary64) (sinh.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 re))) #s(literal 2 binary64))
(/.f64 (fma.f64 #s(literal 2 binary64) (cosh.f64 re) (*.f64 #s(literal 2 binary64) (sinh.f64 re))) #s(literal 2 binary64))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 (neg.f64 re))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (sinh.f64 re) #s(literal 3 binary64)) (pow.f64 (cosh.f64 re) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (sinh.f64 re) (-.f64 (sinh.f64 re) (cosh.f64 re)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64)))))
(/.f64 (fma.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 re)) #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 re)))) #s(literal 4 binary64))
(/.f64 (fma.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 re)) #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (sinh.f64 re)))) #s(literal 4 binary64))
(/.f64 (+.f64 (pow.f64 (sinh.f64 re) #s(literal 3 binary64)) (pow.f64 (cosh.f64 re) #s(literal 3 binary64))) (fma.f64 (sinh.f64 re) (sinh.f64 re) (-.f64 (pow.f64 (cosh.f64 re) #s(literal 2 binary64)) (*.f64 (sinh.f64 re) (cosh.f64 re)))))
(/.f64 (+.f64 (pow.f64 (sinh.f64 re) #s(literal 3 binary64)) (pow.f64 (cosh.f64 re) #s(literal 3 binary64))) (fma.f64 (sinh.f64 re) (-.f64 (sinh.f64 re) (cosh.f64 re)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64))))
(/.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 re)))
(-.f64 (/.f64 (pow.f64 (cosh.f64 re) #s(literal 2 binary64)) (exp.f64 (neg.f64 re))) (/.f64 (pow.f64 (sinh.f64 re) #s(literal 2 binary64)) (exp.f64 (neg.f64 re))))
(exp.f64 re)
(+.f64 (/.f64 (pow.f64 (cosh.f64 re) #s(literal 3 binary64)) (fma.f64 (sinh.f64 re) (-.f64 (sinh.f64 re) (cosh.f64 re)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64)))) (/.f64 (pow.f64 (sinh.f64 re) #s(literal 3 binary64)) (fma.f64 (sinh.f64 re) (-.f64 (sinh.f64 re) (cosh.f64 re)) (pow.f64 (cosh.f64 re) #s(literal 2 binary64)))))
(+.f64 (sinh.f64 re) (cosh.f64 re))
(+.f64 (cosh.f64 re) (sinh.f64 re))
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im))) (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))) (-.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
(fma.f64 (sin.f64 (neg.f64 im)) #s(literal 0 binary64) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(fma.f64 #s(literal 1 binary64) (cos.f64 im) (*.f64 #s(literal 0 binary64) (sin.f64 im)))
(fma.f64 #s(literal 0 binary64) (sin.f64 im) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(fma.f64 (sin.f64 im) #s(literal 0 binary64) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(fma.f64 (cos.f64 im) #s(literal 1 binary64) (*.f64 #s(literal 0 binary64) (sin.f64 im)))
(sin.f64 (+.f64 (neg.f64 im) (/.f64 (PI.f64) #s(literal 2 binary64))))
(sin.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))
(-.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 1 binary64)))
(cos.f64 (neg.f64 im))
(cos.f64 im)
(+.f64 (*.f64 (sin.f64 (neg.f64 im)) #s(literal 0 binary64)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(+.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)))
(+.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))

eval7.0ms (0.1%)

Memory
7.4MiB live, 7.4MiB allocated; 0ms collecting garbage
Compiler

Compiled 1 019 to 220 computations (78.4% saved)

prune5.0ms (0.1%)

Memory
6.8MiB live, 6.8MiB allocated; 0ms collecting garbage
Pruning

8 alts after pruning (7 fresh and 1 done)

PrunedKeptTotal
New61768
Fresh000
Picked011
Done000
Total61869
Accuracy
100.0%
Counts
69 → 8
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.9%
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
100.0%
(*.f64 (exp.f64 re) (cos.f64 im))
62.2%
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
61.8%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
58.0%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
45.9%
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
74.7%
#s(approx (* (exp re) (cos im)) (exp.f64 re))
45.2%
#s(approx (* (exp re) (cos im)) (cos.f64 im))
Compiler

Compiled 227 to 151 computations (33.5% saved)

simplify143.0ms (3.1%)

Memory
-6.9MiB live, 140.6MiB allocated; 38ms collecting garbage
Localize:

Found 16 expressions of interest:

NewMetricScoreProgram
cost-diff0
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
cost-diff0
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
cost-diff0
(exp.f64 re)
cost-diff0
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
cost-diff0
(cos.f64 im)
cost-diff0
(+.f64 #s(literal 1 binary64) re)
cost-diff0
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
cost-diff0
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
cost-diff0
(exp.f64 re)
cost-diff0
#s(approx (* (exp re) (cos im)) (exp.f64 re))
cost-diff0
(cos.f64 im)
cost-diff0
#s(approx (* (exp re) (cos im)) (cos.f64 im))
cost-diff3
(*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
cost-diff3
(fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))
cost-diff3
(*.f64 #s(literal 0 binary64) (sin.f64 im))
cost-diff8
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
032277
054141
1151135
2461127
32989127
08607127
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
(exp.f64 re)
re
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
(+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64)))
(pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64))
(*.f64 #s(literal 0 binary64) (sin.f64 im))
#s(literal 0 binary64)
(sin.f64 im)
im
#s(literal 3 binary64)
(pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))
(*.f64 #s(literal 1 binary64) (cos.f64 im))
#s(literal 1 binary64)
(cos.f64 im)
(fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))
(-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))
(*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
(cos.f64 im)
im
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(exp.f64 re)
re
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
(+.f64 #s(literal 1 binary64) re)
#s(literal 1 binary64)
re
(cos.f64 im)
im
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(exp.f64 re)
re
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(*.f64 im im)
im
#s(literal -1/2 binary64)
#s(literal 1 binary64)
Outputs
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
(*.f64 (cos.f64 im) (exp.f64 re))
(exp.f64 re)
re
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
(cos.f64 im)
(+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64)))
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
(pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64))
#s(literal 0 binary64)
(*.f64 #s(literal 0 binary64) (sin.f64 im))
#s(literal 0 binary64)
#s(literal 0 binary64)
(sin.f64 im)
im
#s(literal 3 binary64)
(pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
(*.f64 #s(literal 1 binary64) (cos.f64 im))
(cos.f64 im)
#s(literal 1 binary64)
(cos.f64 im)
(fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))
(*.f64 (cos.f64 im) (cos.f64 im))
(-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))
(*.f64 (cos.f64 im) (cos.f64 im))
(*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(*.f64 (cos.f64 im) (cos.f64 im))
(*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
#s(literal 0 binary64)
#s(approx (* (exp re) (cos im)) (cos.f64 im))
(cos.f64 im)
im
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(exp.f64 re)
re
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) (cos.f64 im))
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(+.f64 #s(literal 1 binary64) re)
(-.f64 re #s(literal -1 binary64))
#s(literal 1 binary64)
re
(cos.f64 im)
im
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (exp.f64 re))
(exp.f64 re)
re
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))
(*.f64 im im)
im
#s(literal -1/2 binary64)
#s(literal 1 binary64)

localize135.0ms (2.9%)

Memory
-10.5MiB live, 139.8MiB allocated; 22ms collecting garbage
Localize:

Found 16 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 im im)
accuracy0.0
(exp.f64 re)
accuracy0.00390625
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
accuracy32.14628618067625
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
accuracy0.0
(+.f64 #s(literal 1 binary64) re)
accuracy0.0
(cos.f64 im)
accuracy0.00390625
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
accuracy34.61399499604586
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
accuracy0.0
(exp.f64 re)
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) (exp.f64 re))
accuracy0.0
(cos.f64 im)
accuracy35.05853457524884
#s(approx (* (exp re) (cos im)) (cos.f64 im))
accuracy0.00390625
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
accuracy0.22265625
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
accuracy0.25619125976844204
(*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
accuracy0.3867951172213042
(pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))
Samples
116.0ms256×0valid
Compiler

Compiled 255 to 28 computations (89% saved)

Precisions
Click to see histograms. Total time spent on operations: 54.0ms
ival-sin: 17.0ms (31.3% of total)
ival-mult: 11.0ms (20.3% of total)
ival-add: 10.0ms (18.4% of total)
ival-pow: 6.0ms (11.1% of total)
ival-cos: 5.0ms (9.2% of total)
ival-exp: 2.0ms (3.7% of total)
ival-div: 1.0ms (1.8% of total)
ival-sub: 1.0ms (1.8% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series13.0ms (0.3%)

Memory
-22.8MiB live, 20.4MiB allocated; 9ms collecting garbage
Counts
18 → 59
Calls
Call 1
Inputs
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
(*.f64 #s(literal 0 binary64) (sin.f64 im))
(fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))
(*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
(cos.f64 im)
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(exp.f64 re)
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
(+.f64 #s(literal 1 binary64) re)
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))
(*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
(*.f64 im im)
Outputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ 1 re) #s(hole binary64 1))
#s(approx (+ 1 re) #s(hole binary64 (+ 1 re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (+ 1 re) #s(hole binary64 re))
#s(approx (+ 1 re) #s(hole binary64 (* re (+ 1 (/ 1 re)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 1))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (* 0 (sin im)) #s(hole binary64 0))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 1))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (* (* 0 (sin im)) (* 1 (cos im))) #s(hole binary64 0))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 1))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 1))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* -3/2 (pow im 2)))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 7/8 (pow im 2)) 3/2)))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 7/8 (* -61/240 (pow im 2)))) 3/2)))))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 1))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (cos im)))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (pow (cos im) 2)))
#s(approx (cos im) #s(hole binary64 (cos im)))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (* -1/2 (pow im 2))))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (* (pow im 2) (- (/ 1 (pow im 2)) 1/2))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (pow (cos im) 3)))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (pow (cos im) 2)))
Calls

6 calls:

TimeVariablePointExpression
6.0ms
im
@-inf
((/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (* 0 (sin im)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (* (* 0 (sin im)) (* 1 (cos im))) (* (exp re) (cos im)) (cos im) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ 1 re) (* (exp re) (cos im)) (cos im) (+ (* (* im im) -1/2) 1) (pow (* 1 (cos im)) 3) (* (* 1 (cos im)) (* 1 (cos im))) (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (* im im))
2.0ms
im
@inf
((/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (* 0 (sin im)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (* (* 0 (sin im)) (* 1 (cos im))) (* (exp re) (cos im)) (cos im) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ 1 re) (* (exp re) (cos im)) (cos im) (+ (* (* im im) -1/2) 1) (pow (* 1 (cos im)) 3) (* (* 1 (cos im)) (* 1 (cos im))) (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (* im im))
2.0ms
im
@0
((/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (* 0 (sin im)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (* (* 0 (sin im)) (* 1 (cos im))) (* (exp re) (cos im)) (cos im) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ 1 re) (* (exp re) (cos im)) (cos im) (+ (* (* im im) -1/2) 1) (pow (* 1 (cos im)) 3) (* (* 1 (cos im)) (* 1 (cos im))) (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (* im im))
1.0ms
re
@inf
((/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (* 0 (sin im)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (* (* 0 (sin im)) (* 1 (cos im))) (* (exp re) (cos im)) (cos im) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ 1 re) (* (exp re) (cos im)) (cos im) (+ (* (* im im) -1/2) 1) (pow (* 1 (cos im)) 3) (* (* 1 (cos im)) (* 1 (cos im))) (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (* im im))
1.0ms
re
@-inf
((/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (* 0 (sin im)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (* (* 0 (sin im)) (* 1 (cos im))) (* (exp re) (cos im)) (cos im) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ 1 re) (* (exp re) (cos im)) (cos im) (+ (* (* im im) -1/2) 1) (pow (* 1 (cos im)) 3) (* (* 1 (cos im)) (* 1 (cos im))) (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (* im im))

simplify211.0ms (4.6%)

Memory
38.5MiB live, 141.5MiB allocated; 9ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0181973
1501829
21971753
08172695
Stop Event
iter limit
node limit
Counts
59 → 59
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ 1 re) #s(hole binary64 1))
#s(approx (+ 1 re) #s(hole binary64 (+ 1 re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (+ 1 re) #s(hole binary64 re))
#s(approx (+ 1 re) #s(hole binary64 (* re (+ 1 (/ 1 re)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 1))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (* 0 (sin im)) #s(hole binary64 0))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 1))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (* (* 0 (sin im)) (* 1 (cos im))) #s(hole binary64 0))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 1))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 1))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* -3/2 (pow im 2)))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 7/8 (pow im 2)) 3/2)))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 7/8 (* -61/240 (pow im 2)))) 3/2)))))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 1))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (cos im)))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (pow (cos im) 2)))
#s(approx (cos im) #s(hole binary64 (cos im)))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (* -1/2 (pow im 2))))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (* (pow im 2) (- (/ 1 (pow im 2)) 1/2))))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (pow (cos im) 3)))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (pow (cos im) 2)))
Outputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (cos.f64 im))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (cos.f64 im) re (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (*.f64 (cos.f64 im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (*.f64 (cos.f64 im) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))) re (cos.f64 im)))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ 1 re) #s(hole binary64 1))
#s(approx (+ 1 re) #s(literal 1 binary64))
#s(approx (+ 1 re) #s(hole binary64 (+ 1 re)))
#s(approx (+ 1 re) (-.f64 re #s(literal -1 binary64)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (cos.f64 im))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (cos.f64 im) re (cos.f64 im)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (*.f64 (cos.f64 im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (*.f64 (cos.f64 im) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))) re (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (*.f64 (cos.f64 im) (exp.f64 re)))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (exp re) (exp.f64 re))
#s(approx (+ 1 re) #s(hole binary64 re))
#s(approx (+ 1 re) re)
#s(approx (+ 1 re) #s(hole binary64 (* re (+ 1 (/ 1 re)))))
#s(approx (+ 1 re) (-.f64 re #s(literal -1 binary64)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (*.f64 (cos.f64 im) (exp.f64 re)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 1))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(literal 1 binary64))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* 0 (sin im)) #s(hole binary64 0))
#s(approx (* 0 (sin im)) #s(literal 0 binary64))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 1))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(literal 1 binary64))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (-.f64 #s(literal 1 binary64) (*.f64 im im)))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (fma.f64 (fma.f64 #s(literal 1/3 binary64) (*.f64 im im) #s(literal -1 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (fma.f64 (fma.f64 (fma.f64 #s(literal -2/45 binary64) (*.f64 im im) #s(literal 1/3 binary64)) (*.f64 im im) #s(literal -1 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* (* 0 (sin im)) (* 1 (cos im))) #s(hole binary64 0))
#s(approx (* 0 (sin im)) #s(literal 0 binary64))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (exp.f64 re))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (*.f64 (exp.f64 re) (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64))) (*.f64 im im) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (exp.f64 re) (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64))) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(literal 1 binary64))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 1))
#s(approx (+ (* (* im im) -1/2) 1) #s(literal 1 binary64))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (+ (* (* im im) -1/2) 1) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 1))
#s(approx (pow (* 1 (cos im)) 3) #s(literal 1 binary64))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* -3/2 (pow im 2)))))
#s(approx (pow (* 1 (cos im)) 3) (fma.f64 #s(literal -3/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 7/8 (pow im 2)) 3/2)))))
#s(approx (pow (* 1 (cos im)) 3) (fma.f64 (-.f64 (*.f64 #s(literal 7/8 binary64) (*.f64 im im)) #s(literal 3/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 7/8 (* -61/240 (pow im 2)))) 3/2)))))
#s(approx (pow (* 1 (cos im)) 3) (fma.f64 (fma.f64 (pow.f64 im #s(literal 4 binary64)) #s(literal -61/240 binary64) (-.f64 (*.f64 #s(literal 7/8 binary64) (*.f64 im im)) #s(literal 3/2 binary64))) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 1))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(literal 1 binary64))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (-.f64 #s(literal 1 binary64) (*.f64 im im)))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (fma.f64 (fma.f64 #s(literal 1/3 binary64) (*.f64 im im) #s(literal -1 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (fma.f64 (fma.f64 (fma.f64 #s(literal -2/45 binary64) (*.f64 im im) #s(literal 1/3 binary64)) (*.f64 im im) #s(literal -1 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (exp.f64 re))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (*.f64 (exp.f64 re) (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64))) (*.f64 im im) (exp.f64 re)))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))))) (fma.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (exp.f64 re) (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64))) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re))))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (* im im) (*.f64 im im))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) #s(hole binary64 (cos im)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (cos.f64 im))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) #s(hole binary64 (pow (cos im) 2)))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
#s(approx (cos im) #s(hole binary64 (cos im)))
#s(approx (/ (+ (pow (* 0 (sin im)) 3) (pow (* 1 (cos im)) 3)) (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im)))))) (cos.f64 im))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (* -1/2 (pow im 2))))
#s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))
#s(approx (+ (* (* im im) -1/2) 1) #s(hole binary64 (* (pow im 2) (- (/ 1 (pow im 2)) 1/2))))
#s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 im im)) #s(literal 1/2 binary64)) im) im))
#s(approx (pow (* 1 (cos im)) 3) #s(hole binary64 (pow (cos im) 3)))
#s(approx (pow (* 1 (cos im)) 3) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
#s(approx (* (* 1 (cos im)) (* 1 (cos im))) #s(hole binary64 (pow (cos im) 2)))
#s(approx (+ (* (* 0 (sin im)) (* 0 (sin im))) (- (* (* 1 (cos im)) (* 1 (cos im))) (* (* 0 (sin im)) (* 1 (cos im))))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))

rewrite87.0ms (1.9%)

Memory
-31.5MiB live, 100.6MiB allocated; 22ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
032211
054103
124289
0173389
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
18 → 357
Calls
Call 1
Inputs
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))))))
(*.f64 #s(literal 0 binary64) (sin.f64 im))
(fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))
(*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
(cos.f64 im)
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(exp.f64 re)
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (exp re) (+.f64 #s(literal 1 binary64) re))
(+.f64 #s(literal 1 binary64) re)
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))
(*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
(*.f64 im im)
Outputs
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (cos.f64 im) (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (cos.f64 im) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (cos.f64 im))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(/.f64 (+.f64 #s(literal 0 binary64) (*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))) (-.f64 #s(literal 0 binary64) (cos.f64 im)))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 9 binary64)) (*.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(neg.f64 (/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(neg.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 #s(literal 1 binary64) (cos.f64 im) #s(literal 0 binary64))
(fma.f64 (sin.f64 im) (cos.f64 (/.f64 (PI.f64) #s(literal 2 binary64))) (*.f64 (cos.f64 im) (sin.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))))
(sin.f64 (+.f64 (neg.f64 im) (/.f64 (PI.f64) #s(literal 2 binary64))))
(sin.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))
(-.f64 (cos.f64 im) #s(literal 0 binary64))
(-.f64 #s(literal 0 binary64) (neg.f64 (cos.f64 im)))
(cos.f64 (neg.f64 (neg.f64 im)))
(cos.f64 (neg.f64 im))
(cos.f64 im)
(+.f64 (*.f64 (sin.f64 im) (cos.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))) (*.f64 (cos.f64 im) (sin.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))))
(+.f64 (cos.f64 im) #s(literal 0 binary64))
(+.f64 #s(literal 0 binary64) (cos.f64 im))
#s(literal 0 binary64)
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 1 binary64)))
(*.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (neg.f64 (cos.f64 im))))
(*.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (neg.f64 (fabs.f64 (cos.f64 im))))
(*.f64 (fabs.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (fabs.f64 (cos.f64 im))))
(*.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)))
(*.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64))
(*.f64 (cos.f64 im) (cos.f64 im))
(*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(pow.f64 (neg.f64 (cos.f64 im)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 (cos.f64 im)) #s(literal 2 binary64))
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
(/.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (cos.f64 im)) (cos.f64 im))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64))))
(/.f64 (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(/.f64 (+.f64 (sin.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (neg.f64 im))) (sin.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (sin.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) im)) (sin.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) im))) #s(literal 2 binary64))
(/.f64 (-.f64 (cos.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))) (cos.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 (neg.f64 im) (neg.f64 im))) (cos.f64 (-.f64 (neg.f64 im) (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 (neg.f64 im) im)) (cos.f64 (-.f64 (neg.f64 im) im))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 im (neg.f64 im))) (cos.f64 (-.f64 im (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 im im)) (cos.f64 (-.f64 im im))) #s(literal 2 binary64))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(neg.f64 (*.f64 (neg.f64 (cos.f64 im)) (cos.f64 im)))
(neg.f64 (*.f64 (cos.f64 im) (neg.f64 (cos.f64 im))))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 1 binary64)) #s(literal 0 binary64))
(fma.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (neg.f64 (cos.f64 im))) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (neg.f64 (cos.f64 im))) #s(literal 0 binary64))
(fma.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (neg.f64 (fabs.f64 (cos.f64 im))) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (neg.f64 (fabs.f64 (cos.f64 im))) #s(literal 0 binary64))
(fma.f64 (fabs.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (fabs.f64 (cos.f64 im))) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (fabs.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (fabs.f64 (cos.f64 im))) #s(literal 0 binary64))
(fma.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) (cos.f64 im) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (cos.f64 im) (cos.f64 im) #s(literal 0 binary64))
(fma.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 #s(literal 0 binary64) #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im)))))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 4 binary64))))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (sin.f64 (neg.f64 im)) (sin.f64 (neg.f64 im))))
(-.f64 #s(literal 1 binary64) (pow.f64 (sin.f64 im) #s(literal 2 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (cos.f64 im))))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (cos.f64 im))))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal -1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (cos.f64 im)) (cos.f64 im)))
(-.f64 #s(literal 0 binary64) (*.f64 (cos.f64 im) (neg.f64 (cos.f64 im))))
(-.f64 #s(literal 0 binary64) (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(fabs.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 2 binary64)))
(+.f64 (/.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) (neg.f64 im)))))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) im))))
(+.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(+.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(+.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
#s(literal 0 binary64)
#s(approx (* (exp re) (cos im)) (cos.f64 im))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (cos.f64 im) (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (cos.f64 im) #s(literal 1 binary64))
(*.f64 #s(literal 1 binary64) (cos.f64 im))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(/.f64 (+.f64 #s(literal 0 binary64) (*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))) (-.f64 #s(literal 0 binary64) (cos.f64 im)))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 9 binary64)) (*.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(neg.f64 (/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(neg.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 #s(literal 1 binary64) (cos.f64 im) #s(literal 0 binary64))
(fma.f64 (sin.f64 im) (cos.f64 (/.f64 (PI.f64) #s(literal 2 binary64))) (*.f64 (cos.f64 im) (sin.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))))
(sin.f64 (+.f64 (neg.f64 im) (/.f64 (PI.f64) #s(literal 2 binary64))))
(sin.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))
(-.f64 (cos.f64 im) #s(literal 0 binary64))
(-.f64 #s(literal 0 binary64) (neg.f64 (cos.f64 im)))
(cos.f64 (neg.f64 (neg.f64 im)))
(cos.f64 (neg.f64 im))
(cos.f64 im)
(+.f64 (*.f64 (sin.f64 im) (cos.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))) (*.f64 (cos.f64 im) (sin.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))))
(+.f64 (cos.f64 im) #s(literal 0 binary64))
(+.f64 #s(literal 0 binary64) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(/.f64 (-.f64 (*.f64 (cosh.f64 re) (cosh.f64 re)) (*.f64 (sinh.f64 re) (sinh.f64 re))) (-.f64 (cosh.f64 re) (sinh.f64 re)))
(/.f64 (+.f64 (pow.f64 (cosh.f64 re) #s(literal 3 binary64)) (pow.f64 (sinh.f64 re) #s(literal 3 binary64))) (fma.f64 (cosh.f64 re) (cosh.f64 re) (-.f64 (*.f64 (sinh.f64 re) (sinh.f64 re)) (*.f64 (cosh.f64 re) (sinh.f64 re)))))
(exp.f64 re)
(+.f64 (sinh.f64 re) (cosh.f64 re))
(+.f64 (cosh.f64 re) (sinh.f64 re))
(*.f64 (*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(literal 1 binary64)) (cos.f64 im))
(*.f64 (*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) (cos.f64 im)) #s(literal 1 binary64))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) (cos.f64 im))
(*.f64 (cos.f64 im) (*.f64 #s(literal 1 binary64) #s(approx (exp re) (-.f64 re #s(literal -1 binary64)))))
(*.f64 (cos.f64 im) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
(*.f64 #s(literal 1 binary64) (*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) (cos.f64 im)))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(/.f64 (-.f64 (*.f64 re re) #s(literal 1 binary64)) (-.f64 re #s(literal 1 binary64)))
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 re re))) (neg.f64 (-.f64 #s(literal 1 binary64) re)))
(/.f64 (neg.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 re (-.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))))
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 re re)) (-.f64 #s(literal 1 binary64) re))
(/.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1 binary64)) (fma.f64 re re (-.f64 #s(literal 1 binary64) re)))
(/.f64 (+.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1 binary64)) (fma.f64 re (-.f64 re #s(literal 1 binary64)) #s(literal 1 binary64)))
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) re)) (/.f64 (*.f64 re re) (-.f64 #s(literal 1 binary64) re)))
(-.f64 re #s(literal -1 binary64))
(+.f64 (/.f64 #s(literal 1 binary64) (fma.f64 re (-.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))) (/.f64 (pow.f64 re #s(literal 3 binary64)) (fma.f64 re (-.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))))
(+.f64 re #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) re)
(*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (exp.f64 re))
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))))
(fma.f64 (cosh.f64 re) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (*.f64 (sinh.f64 re) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))))
(fma.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (cosh.f64 re) (*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (sinh.f64 re)))
(+.f64 (*.f64 (cosh.f64 re) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))) (*.f64 (sinh.f64 re) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))))
(+.f64 (*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (cosh.f64 re)) (*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) (sinh.f64 re)))
#s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 im im))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal -1 binary64))))
(/.f64 (neg.f64 (fma.f64 #s(literal -1/8 binary64) (pow.f64 (*.f64 im im) #s(literal 3 binary64)) #s(literal 1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 #s(literal -1/2 binary64) (*.f64 im im)))))
(/.f64 (-.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) #s(literal 1 binary64)) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal -1 binary64)))
(/.f64 (fma.f64 #s(literal -1/8 binary64) (pow.f64 (*.f64 im im) #s(literal 3 binary64)) #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) (*.f64 #s(literal -1/2 binary64) (*.f64 im im)))))
(/.f64 (fma.f64 #s(literal -1/8 binary64) (pow.f64 (*.f64 im im) #s(literal 3 binary64)) #s(literal 1 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 #s(literal -1/2 binary64) (*.f64 im im))))
(fma.f64 (*.f64 #s(literal -1/2 binary64) (fabs.f64 im)) (fabs.f64 im) #s(literal 1 binary64))
(fma.f64 (*.f64 #s(literal -1/2 binary64) (neg.f64 im)) (neg.f64 im) #s(literal 1 binary64))
(fma.f64 (*.f64 #s(literal -1/2 binary64) im) im #s(literal 1 binary64))
(fma.f64 (fabs.f64 im) (*.f64 (fabs.f64 im) #s(literal -1/2 binary64)) #s(literal 1 binary64))
(fma.f64 (neg.f64 im) (*.f64 (neg.f64 im) #s(literal -1/2 binary64)) #s(literal 1 binary64))
(fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal -1/2 binary64) (*.f64 (*.f64 im im) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 1 binary64))
(fma.f64 im (*.f64 (*.f64 #s(literal -1/2 binary64) im) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 im (*.f64 #s(literal -1/2 binary64) im) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal -1 binary64))))
(-.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (*.f64 im im)))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (*.f64 im im)) #s(literal -1/2 binary64)))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 im) (*.f64 #s(literal -1/2 binary64) im)))
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 3 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 #s(literal -1/2 binary64) (*.f64 im im)))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 #s(literal -1/2 binary64) (*.f64 im im)))))
(+.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 im im)) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 im im)))
(*.f64 (*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))))
(*.f64 (*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)))
(*.f64 (*.f64 (cos.f64 im) (neg.f64 (cos.f64 im))) (neg.f64 (cos.f64 im)))
(*.f64 (*.f64 (cos.f64 im) (fabs.f64 (cos.f64 im))) (fabs.f64 (cos.f64 im)))
(*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))))
(*.f64 (fabs.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)))
(*.f64 (neg.f64 (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) (cos.f64 im)))
(*.f64 (fabs.f64 (cos.f64 im)) (*.f64 (fabs.f64 (cos.f64 im)) (cos.f64 im)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) #s(literal 1 binary64))
(*.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(pow.f64 (exp.f64 (log.f64 (cos.f64 im))) #s(literal 3 binary64))
(pow.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) #s(literal 2 binary64))
(pow.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 3/2 binary64))
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
(/.f64 (*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (cos.f64 im)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (*.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (cos.f64 im)) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
(/.f64 (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)))) (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)))))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 9 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 9 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64)))
(fma.f64 (*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) #s(literal 0 binary64))
(fma.f64 (*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) #s(literal 0 binary64))
(fma.f64 (*.f64 (cos.f64 im) (neg.f64 (cos.f64 im))) (neg.f64 (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (*.f64 (cos.f64 im) (fabs.f64 (cos.f64 im))) (fabs.f64 (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) #s(literal 0 binary64))
(fma.f64 (fabs.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) #s(literal 0 binary64))
(fma.f64 (neg.f64 (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (fabs.f64 (cos.f64 im)) (*.f64 (fabs.f64 (cos.f64 im)) (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 3 binary64)) #s(literal 0 binary64))
(-.f64 (/.f64 #s(literal 0 binary64) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (/.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)))))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) #s(literal 0 binary64))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (cos.f64 im)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal -1 binary64) (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
(-.f64 #s(literal 0 binary64) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
(exp.f64 (+.f64 #s(literal 0 binary64) (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64))))
(exp.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64)))
(+.f64 (/.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64))) (sinh.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64))))
(+.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) #s(literal 0 binary64))
(+.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 1 binary64)))
(*.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (neg.f64 (cos.f64 im))))
(*.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (neg.f64 (fabs.f64 (cos.f64 im))))
(*.f64 (fabs.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (fabs.f64 (cos.f64 im))))
(*.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)))
(*.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64))
(*.f64 (cos.f64 im) (cos.f64 im))
(*.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(pow.f64 (neg.f64 (cos.f64 im)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 (cos.f64 im)) #s(literal 2 binary64))
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
(/.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (cos.f64 im)) (cos.f64 im))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64))))
(/.f64 (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(/.f64 (+.f64 (sin.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (neg.f64 im))) (sin.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (sin.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) im)) (sin.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) im))) #s(literal 2 binary64))
(/.f64 (-.f64 (cos.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))) (cos.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 (neg.f64 im) (neg.f64 im))) (cos.f64 (-.f64 (neg.f64 im) (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 (neg.f64 im) im)) (cos.f64 (-.f64 (neg.f64 im) im))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 im (neg.f64 im))) (cos.f64 (-.f64 im (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 im im)) (cos.f64 (-.f64 im im))) #s(literal 2 binary64))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 6 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(neg.f64 (*.f64 (neg.f64 (cos.f64 im)) (cos.f64 im)))
(neg.f64 (*.f64 (cos.f64 im) (neg.f64 (cos.f64 im))))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 1 binary64)) #s(literal 0 binary64))
(fma.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (neg.f64 (cos.f64 im))) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (neg.f64 (cos.f64 im))) #s(literal 0 binary64))
(fma.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (neg.f64 (fabs.f64 (cos.f64 im))) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (neg.f64 (fabs.f64 (cos.f64 im))) #s(literal 0 binary64))
(fma.f64 (fabs.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (fabs.f64 (cos.f64 im))) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (fabs.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (fabs.f64 (cos.f64 im))) #s(literal 0 binary64))
(fma.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)) #s(literal 0 binary64))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64) #s(literal 0 binary64))
(fma.f64 (cos.f64 im) (cos.f64 im) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 (cos.f64 im) (cos.f64 im) #s(literal 0 binary64))
(fma.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(fma.f64 #s(literal 1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(fma.f64 #s(literal 0 binary64) #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im)))))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 4 binary64))))
(-.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (sin.f64 (neg.f64 im)) (sin.f64 (neg.f64 im))))
(-.f64 #s(literal 1 binary64) (pow.f64 (sin.f64 im) #s(literal 2 binary64)))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (neg.f64 (cos.f64 im))) (neg.f64 (cos.f64 im))))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (fabs.f64 (cos.f64 im))) (fabs.f64 (cos.f64 im))))
(-.f64 #s(literal 0 binary64) (*.f64 #s(literal -1 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(-.f64 #s(literal 0 binary64) (*.f64 (neg.f64 (cos.f64 im)) (cos.f64 im)))
(-.f64 #s(literal 0 binary64) (*.f64 (cos.f64 im) (neg.f64 (cos.f64 im))))
(-.f64 #s(literal 0 binary64) (/.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(fabs.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(exp.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 2 binary64)))
(+.f64 (/.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 4 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) (neg.f64 im)))))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) im))))
(+.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (neg.f64 (cos.f64 im)) #s(literal 0 binary64)))
(+.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 0 binary64))
(+.f64 #s(literal 0 binary64) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 4 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 6 binary64))) (pow.f64 (cos.f64 im) #s(literal 4 binary64)))
(*.f64 (*.f64 (exp.f64 re) #s(literal 1 binary64)) (cos.f64 im))
(*.f64 (exp.f64 re) (cos.f64 im))
(*.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 1 binary64))
(*.f64 (cos.f64 im) (*.f64 #s(literal 1 binary64) (exp.f64 re)))
(*.f64 (cos.f64 im) (exp.f64 re))
(*.f64 #s(literal 1 binary64) (*.f64 (exp.f64 re) (cos.f64 im)))
(/.f64 (*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (exp.f64 re)) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (*.f64 (exp.f64 re) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(/.f64 (neg.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(fma.f64 (cosh.f64 re) (cos.f64 im) (*.f64 (sinh.f64 re) (cos.f64 im)))
(fma.f64 (exp.f64 re) #s(literal 0 binary64) (*.f64 (exp.f64 re) (cos.f64 im)))
(fma.f64 (cos.f64 im) (cosh.f64 re) (*.f64 (cos.f64 im) (sinh.f64 re)))
(fma.f64 #s(literal 0 binary64) (exp.f64 re) (*.f64 (exp.f64 re) (cos.f64 im)))
(+.f64 (*.f64 #s(literal 0 binary64) (exp.f64 re)) (*.f64 (exp.f64 re) (cos.f64 im)))
(+.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im)))
(+.f64 (*.f64 (exp.f64 re) #s(literal 0 binary64)) (*.f64 (exp.f64 re) (cos.f64 im)))
(+.f64 (*.f64 (cos.f64 im) (cosh.f64 re)) (*.f64 (cos.f64 im) (sinh.f64 re)))
(*.f64 (pow.f64 im #s(literal 1 binary64)) (pow.f64 im #s(literal 1 binary64)))
(*.f64 (neg.f64 (fabs.f64 im)) (neg.f64 (fabs.f64 im)))
(*.f64 (fabs.f64 (fabs.f64 im)) (fabs.f64 (fabs.f64 im)))
(*.f64 (neg.f64 (neg.f64 im)) (neg.f64 (neg.f64 im)))
(*.f64 (fabs.f64 im) (fabs.f64 im))
(*.f64 (neg.f64 im) (neg.f64 im))
(*.f64 im im)
(pow.f64 (fabs.f64 im) #s(literal 2 binary64))
(pow.f64 (neg.f64 im) #s(literal 2 binary64))
(pow.f64 im #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 im) im))
(neg.f64 (*.f64 im (neg.f64 im)))
(fabs.f64 (*.f64 im im))
(exp.f64 (*.f64 (log.f64 im) #s(literal 2 binary64)))

eval45.0ms (1%)

Memory
27.0MiB live, 81.5MiB allocated; 15ms collecting garbage
Compiler

Compiled 8 735 to 1 125 computations (87.1% saved)

prune14.0ms (0.3%)

Memory
5.4MiB live, 52.6MiB allocated; 3ms collecting garbage
Pruning

16 alts after pruning (12 fresh and 4 done)

PrunedKeptTotal
New30210312
Fresh022
Picked235
Done011
Total30416320
Accuracy
100.0%
Counts
320 → 16
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.9%
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
100.0%
(*.f64 (exp.f64 re) (cos.f64 im))
30.0%
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
61.8%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
33.6%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
58.0%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
32.1%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
27.0%
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
45.9%
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
24.9%
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
74.7%
#s(approx (* (exp re) (cos im)) (exp.f64 re))
45.2%
#s(approx (* (exp re) (cos im)) (cos.f64 im))
38.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
35.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
25.6%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
25.1%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
Compiler

Compiled 410 to 311 computations (24.1% saved)

simplify201.0ms (4.4%)

Memory
-16.6MiB live, 214.6MiB allocated; 50ms collecting garbage
Localize:

Found 18 expressions of interest:

NewMetricScoreProgram
cost-diff0
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
cost-diff0
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
cost-diff0
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
cost-diff0
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
cost-diff0
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
cost-diff0
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
cost-diff0
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
cost-diff0
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
cost-diff0
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
cost-diff0
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
cost-diff0
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
cost-diff0
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
cost-diff0
#s(approx (exp re) #s(literal 1 binary64))
cost-diff0
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
cost-diff0
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
cost-diff0
(exp.f64 re)
cost-diff0
(*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
cost-diff7
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
032211
054211
191211
2233206
3888204
46020204
08976204
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(exp.f64 re)
re
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
(cos.f64 im)
im
#s(literal 3 binary64)
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
#s(literal 2 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (exp re) #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(literal 1/2 binary64)
re
#s(literal 1 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
re
#s(literal 1/2 binary64)
#s(literal 1 binary64)
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(literal 1/2 binary64)
re
#s(literal 1 binary64)
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(*.f64 im im)
im
#s(literal -1/2 binary64)
Outputs
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (exp.f64 re) (cos.f64 im))
(*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(exp.f64 re)
re
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
(cos.f64 im)
im
#s(literal 3 binary64)
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
#s(literal 2 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (exp re) #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(literal 1/2 binary64)
re
#s(literal 1 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
re
#s(literal 1/2 binary64)
#s(literal 1 binary64)
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(literal 1/2 binary64)
re
#s(literal 1 binary64)
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))
(*.f64 im im)
im
#s(literal -1/2 binary64)

localize118.0ms (2.6%)

Memory
16.1MiB live, 160.3MiB allocated; 25ms collecting garbage
Localize:

Found 18 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 im im)
accuracy0.00390625
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
accuracy26.68652929973071
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
accuracy32.14628618067625
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
accuracy0.0625
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
accuracy0.20703125
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
accuracy24.284135310902748
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
accuracy0.0
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
accuracy0.0
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
accuracy26.68652929973071
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
accuracy34.855295553181165
#s(approx (exp re) #s(literal 1 binary64))
accuracy0.0
(cos.f64 im)
accuracy0.109375
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
accuracy0.25619125976844204
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
accuracy0.3867951172213042
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
Samples
93.0ms255×0valid
1.0ms5exit
Compiler

Compiled 145 to 30 computations (79.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 77.0ms
ival-add: 28.0ms (36.4% of total)
ival-mult: 27.0ms (35.1% of total)
ival-cos: 6.0ms (7.8% of total)
ival-exp: 5.0ms (6.5% of total)
const: 4.0ms (5.2% of total)
ival-pow: 3.0ms (3.9% of total)
ival-div: 2.0ms (2.6% of total)
ival-pow2: 2.0ms (2.6% of total)
exact: 1.0ms (1.3% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)

series14.0ms (0.3%)

Memory
-9.4MiB live, 36.8MiB allocated; 4ms collecting garbage
Counts
20 → 78
Calls
Call 1
Inputs
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(exp.f64 re)
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
(cos.f64 im)
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(*.f64 im im)
Outputs
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (cos im)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (pow (cos im) 3)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (pow (cos im) 3)) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (+ (* 1/2 (* re (pow (cos im) 3))) (pow (cos im) 3))) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (+ (* re (+ (* 1/6 (* re (pow (cos im) 3))) (* 1/2 (pow (cos im) 3)))) (pow (cos im) 3))) (pow (cos im) 3))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 1))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* re (+ 1/2 (* 1/6 re))))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (+ 1/2 (* 1/6 re))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (* (pow (cos im) 3) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))))))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (* 1/2 re)))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (* re (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (+ (/ 1 (pow re 2)) (/ 1 (pow re 3))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* 1/6 (pow re 2))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* 1/6 re)))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* re (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))) re)) 1/6)))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (exp re)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* -3/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -3/2 (exp re)) (* 7/8 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -3/2 (exp re)) (* (pow im 2) (+ (* -61/240 (* (pow im 2) (exp re))) (* 7/8 (exp re)))))))))
#s(approx (pow (cos im) 3) #s(hole binary64 1))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* -3/2 (pow im 2)))))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 7/8 (pow im 2)) 3/2)))))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 7/8 (* -61/240 (pow im 2)))) 3/2)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (pow (cos im) 2) #s(hole binary64 1))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (pow (cos im) 3) #s(hole binary64 (pow (cos im) 3)))
#s(approx (pow (cos im) 2) #s(hole binary64 (pow (cos im) 2)))
#s(approx (cos im) #s(hole binary64 (cos im)))
Calls

6 calls:

TimeVariablePointExpression
6.0ms
re
@inf
((/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (* (exp re) (pow (cos im) 3)) (exp re) (pow (cos im) 3) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (+ (* 1/2 re) 1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (pow (cos im) 2) (cos im) (+ (* 1/6 re) 1/2) (cos im) (* im im))
2.0ms
re
@-inf
((/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (* (exp re) (pow (cos im) 3)) (exp re) (pow (cos im) 3) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (+ (* 1/2 re) 1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (pow (cos im) 2) (cos im) (+ (* 1/6 re) 1/2) (cos im) (* im im))
1.0ms
re
@0
((/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (* (exp re) (pow (cos im) 3)) (exp re) (pow (cos im) 3) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (+ (* 1/2 re) 1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (pow (cos im) 2) (cos im) (+ (* 1/6 re) 1/2) (cos im) (* im im))
1.0ms
im
@inf
((/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (* (exp re) (pow (cos im) 3)) (exp re) (pow (cos im) 3) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (+ (* 1/2 re) 1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (pow (cos im) 2) (cos im) (+ (* 1/6 re) 1/2) (cos im) (* im im))
1.0ms
im
@-inf
((/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (* (exp re) (pow (cos im) 3)) (exp re) (pow (cos im) 3) (* (exp re) (cos im)) (exp re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (+ (* 1/2 re) 1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (pow (cos im) 2) (cos im) (+ (* 1/6 re) 1/2) (cos im) (* im im))

simplify151.0ms (3.3%)

Memory
-9.5MiB live, 175.3MiB allocated; 21ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02531359
16871312
227571302
085941165
Stop Event
iter limit
node limit
Counts
78 → 78
Calls
Call 1
Inputs
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (cos im)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (pow (cos im) 3)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (pow (cos im) 3)) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (+ (* 1/2 (* re (pow (cos im) 3))) (pow (cos im) 3))) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (+ (* re (+ (* 1/6 (* re (pow (cos im) 3))) (* 1/2 (pow (cos im) 3)))) (pow (cos im) 3))) (pow (cos im) 3))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 1))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* re (+ 1/2 (* 1/6 re))))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (+ 1/2 (* 1/6 re))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (* (pow (cos im) 3) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))))))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (* 1/2 re)))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (* re (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (+ (/ 1 (pow re 2)) (/ 1 (pow re 3))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* 1/6 (pow re 2))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* 1/6 re)))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* re (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))) re)) 1/6)))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (exp re)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* -3/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -3/2 (exp re)) (* 7/8 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -3/2 (exp re)) (* (pow im 2) (+ (* -61/240 (* (pow im 2) (exp re))) (* 7/8 (exp re)))))))))
#s(approx (pow (cos im) 3) #s(hole binary64 1))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* -3/2 (pow im 2)))))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 7/8 (pow im 2)) 3/2)))))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 7/8 (* -61/240 (pow im 2)))) 3/2)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (pow (cos im) 2) #s(hole binary64 1))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (pow (cos im) 3) #s(hole binary64 (pow (cos im) 3)))
#s(approx (pow (cos im) 2) #s(hole binary64 (pow (cos im) 2)))
#s(approx (cos im) #s(hole binary64 (cos im)))
Outputs
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (cos im)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (cos.f64 im))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (fma.f64 (cos.f64 im) re (cos.f64 im)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) (cos.f64 im)) re (cos.f64 im)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (fma.f64 (fma.f64 (*.f64 (cos.f64 im) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) re (cos.f64 im)) re (cos.f64 im)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (pow (cos im) 3)))
#s(approx (* (exp re) (pow (cos im) 3)) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (pow (cos im) 3)) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) (*.f64 (-.f64 re #s(literal -1 binary64)) (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (+ (* 1/2 (* re (pow (cos im) 3))) (pow (cos im) 3))) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) re (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (* re (+ (* re (+ (* 1/6 (* re (pow (cos im) 3))) (* 1/2 (pow (cos im) 3)))) (pow (cos im) 3))) (pow (cos im) 3))))
#s(approx (* (exp re) (pow (cos im) 3)) (fma.f64 (*.f64 re re) (*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) (*.f64 (-.f64 re #s(literal -1 binary64)) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) (fma.f64 (cos.f64 im) re (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) (cos.f64 im)) re (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (fma.f64 (*.f64 (cos.f64 im) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) re (cos.f64 im)) re (cos.f64 im)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (-.f64 re #s(literal -1 binary64)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 1))
#s(approx (+ (* 1/2 re) 1) #s(literal 1 binary64))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* 1/2 re) 1) (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(literal 1 binary64))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (-.f64 re #s(literal -1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(literal 1 binary64))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* re (+ 1/2 (* 1/6 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (+ 1/2 (* 1/6 re))))
#s(approx (+ (* 1/6 re) 1/2) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (*.f64 (cos.f64 im) (exp.f64 re)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (* (pow (cos im) 3) (exp re))))
#s(approx (* (exp re) (pow (cos im) 3)) (*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (exp.f64 re)))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (exp re) (exp.f64 re))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (cos im)) (*.f64 (cos.f64 im) (exp.f64 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (* 1/2 re)))
#s(approx (+ (* 1/2 re) 1) (*.f64 #s(literal 1/2 binary64) re))
#s(approx (+ (* 1/2 re) 1) #s(hole binary64 (* re (+ 1/2 (/ 1 re)))))
#s(approx (+ (* 1/2 re) 1) (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (+ (/ 1 (pow re 2)) (/ 1 (pow re 3))))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (+.f64 (/.f64 (-.f64 (/.f64 (+.f64 (/.f64 #s(literal 1 binary64) re) #s(literal 1 binary64)) re) #s(literal -1/2 binary64)) re) #s(literal 1/6 binary64)) (pow.f64 re #s(literal 3 binary64))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* 1/6 (pow re 2))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* 1/6 re)))
#s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* re (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* 1/6 re) 1/2) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (pow.f64 (neg.f64 re) #s(literal 3 binary64)) (-.f64 (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) re)) re) #s(literal 1/6 binary64))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (pow.f64 (neg.f64 re) #s(literal 3 binary64)) (-.f64 (/.f64 (neg.f64 (-.f64 (/.f64 (+.f64 (/.f64 #s(literal 1 binary64) re) #s(literal 1 binary64)) re) #s(literal -1/2 binary64))) re) #s(literal 1/6 binary64))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (exp re)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (exp.f64 re))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (fma.f64 (*.f64 (exp.f64 re) (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64))) (*.f64 im im) (exp.f64 re)))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (/ (* (exp re) (pow (cos im) 3)) (pow (cos im) 2)) (fma.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re) (*.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (exp.f64 re) (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64))))))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (pow (cos im) 3)) (exp.f64 re))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* -3/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (pow (cos im) 3)) (*.f64 (fma.f64 #s(literal -3/2 binary64) (*.f64 im im) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -3/2 (exp re)) (* 7/8 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (pow (cos im) 3)) (fma.f64 (*.f64 (exp.f64 re) (fma.f64 #s(literal 7/8 binary64) (*.f64 im im) #s(literal -3/2 binary64))) (*.f64 im im) (exp.f64 re)))
#s(approx (* (exp re) (pow (cos im) 3)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -3/2 (exp re)) (* (pow im 2) (+ (* -61/240 (* (pow im 2) (exp re))) (* 7/8 (exp re)))))))))
#s(approx (* (exp re) (pow (cos im) 3)) (fma.f64 (fma.f64 #s(literal -3/2 binary64) (*.f64 im im) #s(literal 1 binary64)) (exp.f64 re) (*.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (exp.f64 re) (fma.f64 #s(literal -61/240 binary64) (*.f64 im im) #s(literal 7/8 binary64))))))
#s(approx (pow (cos im) 3) #s(hole binary64 1))
#s(approx (pow (cos im) 3) #s(literal 1 binary64))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* -3/2 (pow im 2)))))
#s(approx (pow (cos im) 3) (fma.f64 #s(literal -3/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 7/8 (pow im 2)) 3/2)))))
#s(approx (pow (cos im) 3) (fma.f64 (-.f64 (*.f64 #s(literal 7/8 binary64) (*.f64 im im)) #s(literal 3/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (pow (cos im) 3) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 7/8 (* -61/240 (pow im 2)))) 3/2)))))
#s(approx (pow (cos im) 3) (fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal -61/240 binary64) (*.f64 im im) #s(literal 7/8 binary64)) im) im) #s(literal 3/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (*.f64 (exp.f64 re) (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64))) (*.f64 im im) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re) (*.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (exp.f64 re) (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64))))))
#s(approx (pow (cos im) 2) #s(hole binary64 1))
#s(approx (pow (cos im) 2) #s(literal 1 binary64))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* -1 (pow im 2)))))
#s(approx (pow (cos im) 2) (-.f64 #s(literal 1 binary64) (*.f64 im im)))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/3 (pow im 2)) 1)))))
#s(approx (pow (cos im) 2) (fma.f64 (fma.f64 #s(literal 1/3 binary64) (*.f64 im im) #s(literal -1 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (pow (cos im) 2) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/3 (* -2/45 (pow im 2)))) 1)))))
#s(approx (pow (cos im) 2) (fma.f64 (fma.f64 (fma.f64 #s(literal -2/45 binary64) (*.f64 im im) #s(literal 1/3 binary64)) (*.f64 im im) #s(literal -1 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(literal 1 binary64))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (* im im) (*.f64 im im))
#s(approx (pow (cos im) 3) #s(hole binary64 (pow (cos im) 3)))
#s(approx (pow (cos im) 3) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
#s(approx (pow (cos im) 2) #s(hole binary64 (pow (cos im) 2)))
#s(approx (pow (cos im) 2) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
#s(approx (cos im) #s(hole binary64 (cos im)))
#s(approx (cos im) (cos.f64 im))

rewrite62.0ms (1.3%)

Memory
33.6MiB live, 79.1MiB allocated; 4ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
032167
054167
1174160
01266160
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
20 → 199
Calls
Call 1
Inputs
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(exp.f64 re)
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
(cos.f64 im)
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(*.f64 im im)
Outputs
(*.f64 (/.f64 (exp.f64 re) (cos.f64 im)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (cos.f64 im)))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (cos.f64 im)) (/.f64 (exp.f64 re) (cos.f64 im)))
(*.f64 (exp.f64 re) (cos.f64 im))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (/.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (cos.f64 im) (exp.f64 re))
(/.f64 (/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (cos.f64 im)) (cos.f64 im))
(/.f64 (neg.f64 (*.f64 (neg.f64 (exp.f64 re)) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))) (neg.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(/.f64 (*.f64 (neg.f64 (exp.f64 re)) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(neg.f64 (/.f64 (*.f64 (neg.f64 (exp.f64 re)) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(neg.f64 (/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)))))
(fma.f64 (cosh.f64 re) (cos.f64 im) (*.f64 (sinh.f64 re) (cos.f64 im)))
(fma.f64 (cos.f64 im) (cosh.f64 re) (*.f64 (cos.f64 im) (sinh.f64 re)))
(+.f64 (*.f64 (cosh.f64 re) (cos.f64 im)) (*.f64 (sinh.f64 re) (cos.f64 im)))
(+.f64 (*.f64 (cos.f64 im) (cosh.f64 re)) (*.f64 (cos.f64 im) (sinh.f64 re)))
(*.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)))
(*.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 2 binary64))) (cos.f64 im))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (exp.f64 re)))
(*.f64 (*.f64 (exp.f64 re) (cos.f64 im)) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (*.f64 (exp.f64 re) (cos.f64 im)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (exp.f64 re))
(*.f64 (cos.f64 im) (*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (exp.f64 re)))
(fma.f64 (cosh.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (*.f64 (sinh.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
(fma.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (cosh.f64 re) (*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (sinh.f64 re)))
(exp.f64 (+.f64 re (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64))))
(exp.f64 (fma.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64) re))
(+.f64 (*.f64 (cosh.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (*.f64 (sinh.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))))
(+.f64 (*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (cosh.f64 re)) (*.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (sinh.f64 re)))
(/.f64 (-.f64 (*.f64 (cosh.f64 re) (cosh.f64 re)) (*.f64 (sinh.f64 re) (sinh.f64 re))) (-.f64 (cosh.f64 re) (sinh.f64 re)))
(/.f64 (+.f64 (pow.f64 (cosh.f64 re) #s(literal 3 binary64)) (pow.f64 (sinh.f64 re) #s(literal 3 binary64))) (fma.f64 (cosh.f64 re) (cosh.f64 re) (-.f64 (*.f64 (sinh.f64 re) (sinh.f64 re)) (*.f64 (cosh.f64 re) (sinh.f64 re)))))
(exp.f64 re)
(+.f64 (sinh.f64 re) (cosh.f64 re))
(+.f64 (cosh.f64 re) (sinh.f64 re))
(*.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))))
(*.f64 (fabs.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64))))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im))
(*.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(pow.f64 (exp.f64 (log.f64 (cos.f64 im))) #s(literal 3 binary64))
(pow.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) #s(literal 2 binary64))
(pow.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 3/2 binary64))
(pow.f64 (cos.f64 im) #s(literal 3 binary64))
(exp.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64))) (sinh.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(fma.f64 re (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 re (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal -1 binary64))))
(-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))) re))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))))
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
(+.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re)))
(/.f64 (neg.f64 (fma.f64 (*.f64 re re) #s(literal 1/4 binary64) #s(literal -1 binary64))) (neg.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal -1 binary64))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64))) (neg.f64 (fma.f64 (*.f64 re re) #s(literal 1/4 binary64) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re)))))
(/.f64 (fma.f64 (*.f64 re re) #s(literal 1/4 binary64) #s(literal -1 binary64)) (fma.f64 #s(literal 1/2 binary64) re #s(literal -1 binary64)))
(/.f64 (fma.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) re))))
(/.f64 (fma.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64)) (fma.f64 (*.f64 re re) #s(literal 1/4 binary64) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re))))
(fma.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) (*.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re) #s(literal 1 binary64))
(fma.f64 re #s(literal 1/2 binary64) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal 2 binary64)) (fma.f64 #s(literal 1/2 binary64) re #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 #s(literal 1/2 binary64) re #s(literal -1 binary64))))
(-.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) re))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 re) #s(literal 1/2 binary64)))
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal 3 binary64)) (fma.f64 (*.f64 re re) #s(literal 1/4 binary64) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re)))) (/.f64 #s(literal 1 binary64) (fma.f64 (*.f64 re re) #s(literal 1/4 binary64) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re)))))
(+.f64 (*.f64 #s(literal 1/2 binary64) re) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
(fma.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(fma.f64 re (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 re (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64))))
(-.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))) re))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 re) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))))
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
(+.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re)))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 1 binary64))
(fma.f64 re (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 re (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64))))
(-.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) re))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))))
(+.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))
(*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))))
(*.f64 (neg.f64 (cos.f64 im)) (neg.f64 (cos.f64 im)))
(*.f64 (fabs.f64 (cos.f64 im)) (fabs.f64 (cos.f64 im)))
(*.f64 (exp.f64 (log.f64 (cos.f64 im))) (exp.f64 (log.f64 (cos.f64 im))))
(*.f64 (cos.f64 im) (cos.f64 im))
(pow.f64 (exp.f64 (log.f64 (cos.f64 im))) #s(literal 2 binary64))
(pow.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) #s(literal 1 binary64))
(pow.f64 (cos.f64 im) #s(literal 2 binary64))
(/.f64 (+.f64 (sin.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (neg.f64 im))) (sin.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (sin.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) im)) (sin.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) im))) #s(literal 2 binary64))
(/.f64 (-.f64 (cos.f64 (-.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))) (cos.f64 (+.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 (neg.f64 im) (neg.f64 im))) (cos.f64 (-.f64 (neg.f64 im) (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 (neg.f64 im) im)) (cos.f64 (-.f64 (neg.f64 im) im))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 im (neg.f64 im))) (cos.f64 (-.f64 im (neg.f64 im)))) #s(literal 2 binary64))
(/.f64 (+.f64 (cos.f64 (+.f64 im im)) (cos.f64 (-.f64 im im))) #s(literal 2 binary64))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im)))))
(-.f64 #s(literal 1 binary64) (*.f64 (sin.f64 (neg.f64 im)) (sin.f64 (neg.f64 im))))
(-.f64 #s(literal 1 binary64) (*.f64 (sin.f64 im) (sin.f64 im)))
(exp.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 2 binary64))))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) (neg.f64 im)))))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 (*.f64 #s(literal 2 binary64) im))))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 1/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 1/2 binary64)))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (cos.f64 im)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (cos.f64 im)))
(*.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im)) (/.f64 (cos.f64 im) (cos.f64 im)))
(*.f64 (/.f64 (cos.f64 im) (cos.f64 im)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (cos.f64 im)))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (/.f64 (pow.f64 (cos.f64 im) #s(literal 3/2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (/.f64 (cos.f64 im) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(*.f64 (cos.f64 im) (/.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(pow.f64 (cos.f64 im) #s(literal 1 binary64))
(/.f64 (/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (cos.f64 im)) (cos.f64 im))
(/.f64 (neg.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (neg.f64 (pow.f64 (cos.f64 im) #s(literal 2 binary64))))
(/.f64 (pow.f64 (cos.f64 im) #s(literal 3 binary64)) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(fma.f64 (sin.f64 im) (cos.f64 (/.f64 (PI.f64) #s(literal 2 binary64))) (*.f64 (cos.f64 im) (sin.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))))
(sin.f64 (+.f64 (neg.f64 im) (/.f64 (PI.f64) #s(literal 2 binary64))))
(sin.f64 (+.f64 (/.f64 (PI.f64) #s(literal 2 binary64)) im))
(cos.f64 (neg.f64 (neg.f64 im)))
(cos.f64 (neg.f64 im))
(cos.f64 im)
(exp.f64 (-.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 3 binary64)) (*.f64 (log.f64 (cos.f64 im)) #s(literal 2 binary64))))
(exp.f64 (*.f64 (log.f64 (cos.f64 im)) #s(literal 1 binary64)))
(+.f64 (*.f64 (sin.f64 im) (cos.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))) (*.f64 (cos.f64 im) (sin.f64 (/.f64 (PI.f64) #s(literal 2 binary64)))))
(/.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 2 binary64))) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/6 binary64) re)))
(/.f64 (neg.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64))) (neg.f64 (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))
(/.f64 (neg.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64))) (neg.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64))))))
(/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))
(/.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 2 binary64)) (*.f64 re #s(literal 1/12 binary64)))))
(/.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64)) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64)))))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
(fma.f64 re #s(literal 1/6 binary64) #s(literal 1/2 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/6 binary64) re))
(-.f64 #s(literal 1/2 binary64) (*.f64 (neg.f64 re) #s(literal 1/6 binary64)))
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 3 binary64)) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64))))) (/.f64 #s(literal 1/8 binary64) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64))))))
(+.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/6 binary64) re))
#s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
(*.f64 (neg.f64 (fabs.f64 im)) (neg.f64 (fabs.f64 im)))
(*.f64 (fabs.f64 (fabs.f64 im)) (fabs.f64 (fabs.f64 im)))
(*.f64 (pow.f64 im #s(literal 1 binary64)) (pow.f64 im #s(literal 1 binary64)))
(*.f64 (pow.f64 im #s(literal 1 binary64)) im)
(*.f64 (neg.f64 (neg.f64 im)) (neg.f64 (neg.f64 im)))
(*.f64 (fabs.f64 im) (fabs.f64 im))
(*.f64 (neg.f64 im) (neg.f64 im))
(*.f64 im im)
(pow.f64 (fabs.f64 im) #s(literal 2 binary64))
(pow.f64 (neg.f64 im) #s(literal 2 binary64))
(pow.f64 im #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 im) im))
(neg.f64 (*.f64 im (neg.f64 im)))
(fabs.f64 (*.f64 im im))
(exp.f64 (*.f64 (log.f64 im) #s(literal 2 binary64)))

eval61.0ms (1.3%)

Memory
-30.8MiB live, 68.5MiB allocated; 13ms collecting garbage
Compiler

Compiled 7 698 to 1 231 computations (84% saved)

prune18.0ms (0.4%)

Memory
33.1MiB live, 33.1MiB allocated; 0ms collecting garbage
Pruning

23 alts after pruning (15 fresh and 8 done)

PrunedKeptTotal
New3319340
Fresh167
Picked145
Done044
Total33323356
Accuracy
100.0%
Counts
356 → 23
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.9%
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
100.0%
(*.f64 (exp.f64 re) (cos.f64 im))
30.0%
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
61.8%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
33.6%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
58.0%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
27.0%
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
45.9%
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
12.3%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
12.3%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
24.9%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
74.7%
#s(approx (* (exp re) (cos im)) (exp.f64 re))
45.2%
#s(approx (* (exp re) (cos im)) (cos.f64 im))
38.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
38.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
35.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
37.7%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
25.6%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
16.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
16.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
13.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
13.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
25.1%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
Compiler

Compiled 779 to 577 computations (25.9% saved)

simplify135.0ms (2.9%)

Memory
-3.3MiB live, 139.2MiB allocated; 30ms collecting garbage
Localize:

Found 19 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)
cost-diff0
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
cost-diff0
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
cost-diff0
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
cost-diff0
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)
cost-diff0
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
cost-diff0
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
cost-diff0
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
cost-diff0
(*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
cost-diff0
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
cost-diff0
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))
cost-diff0
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
cost-diff0
(-.f64 re #s(literal -1 binary64))
cost-diff0
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
cost-diff0
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
cost-diff0
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
cost-diff0
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
cost-diff0
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
cost-diff0
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
046357
063357
1108357
2264357
3846357
42463357
08143354
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
re
#s(literal 1/2 binary64)
#s(literal 1 binary64)
(cos.f64 im)
im
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(-.f64 re #s(literal -1 binary64))
re
#s(literal -1 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
(*.f64 re re)
re
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
#s(literal 1/2 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
re
#s(literal 1/2 binary64)
#s(literal 1 binary64)
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(literal 1/2 binary64)
re
#s(literal 1 binary64)
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(*.f64 im im)
im
#s(literal -1/2 binary64)
Outputs
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 (cos.f64 im) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
re
#s(literal 1/2 binary64)
#s(literal 1 binary64)
(cos.f64 im)
im
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(-.f64 re #s(literal -1 binary64))
re
#s(literal -1 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
(*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
(*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re)
(*.f64 re re)
re
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
#s(literal 1/2 binary64)
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(literal 1/6 binary64)
re
#s(literal 1/2 binary64)
#s(literal 1 binary64)
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)
(fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64))
#s(literal 1/2 binary64)
re
#s(literal 1 binary64)
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))
(fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))
(*.f64 im im)
im
#s(literal -1/2 binary64)

localize91.0ms (2%)

Memory
-23.9MiB live, 112.7MiB allocated; 16ms collecting garbage
Localize:

Found 19 expressions of interest:

NewMetricScoreProgram
accuracy0.00390625
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
accuracy26.68652929973071
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
accuracy27.3920400318816
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
accuracy32.14628618067625
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
accuracy0.20703125
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
accuracy24.284135310902748
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
accuracy27.22169409314017
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
accuracy0.20703125
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
accuracy24.284135310902748
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))
accuracy27.288896969226556
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
accuracy0.0
(-.f64 re #s(literal -1 binary64))
accuracy16.21782373576935
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
accuracy34.41735895647951
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
accuracy0.05078125
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
accuracy0.0625
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
accuracy0.20703125
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
accuracy24.284135310902748
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
Samples
55.0ms255×0valid
1.0ms5exit
Compiler

Compiled 189 to 28 computations (85.2% saved)

Precisions
Click to see histograms. Total time spent on operations: 36.0ms
ival-mult: 16.0ms (43.9% of total)
ival-cos: 6.0ms (16.5% of total)
ival-add: 6.0ms (16.5% of total)
const: 4.0ms (11% of total)
ival-exp: 2.0ms (5.5% of total)
ival-sub: 1.0ms (2.7% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series7.0ms (0.2%)

Memory
10.7MiB live, 10.6MiB allocated; 0ms collecting garbage
Counts
21 → 64
Calls
Call 1
Inputs
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(-.f64 re #s(literal -1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
Outputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* re (+ 1/2 (* 1/6 re))))))
#s(approx (- re -1) #s(hole binary64 1))
#s(approx (- re -1) #s(hole binary64 (+ 1 re)))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* (pow re 2) (+ 1/2 (* 1/6 re)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* re (+ 1 (* 1/2 re)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* re (+ 1 (* re (+ 1/2 (* 1/6 re)))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 re))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* re (+ 1 (* 1/2 re)))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (+ 1/2 (* 1/6 re))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (+ (/ 1 (pow re 2)) (/ 1 (pow re 3))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* 1/6 (pow re 2))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (- re -1) #s(hole binary64 re))
#s(approx (- re -1) #s(hole binary64 (* re (+ 1 (/ 1 re)))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))))))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* 1/6 re)))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* re (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))) re)) 1/6)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) #s(hole binary64 (cos im)))
Calls

6 calls:

TimeVariablePointExpression
2.0ms
re
@inf
((* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (exp re) (- re -1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (* re re) (+ (* 1/6 re) 1/2)) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (* (+ (* 1/2 re) 1) re) (+ (* 1/6 re) 1/2) (cos im))
2.0ms
re
@-inf
((* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (exp re) (- re -1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (* re re) (+ (* 1/6 re) 1/2)) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (* (+ (* 1/2 re) 1) re) (+ (* 1/6 re) 1/2) (cos im))
1.0ms
re
@0
((* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (exp re) (- re -1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (* re re) (+ (* 1/6 re) 1/2)) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (* (+ (* 1/2 re) 1) re) (+ (* 1/6 re) 1/2) (cos im))
0.0ms
im
@inf
((* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (exp re) (- re -1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (* re re) (+ (* 1/6 re) 1/2)) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (* (+ (* 1/2 re) 1) re) (+ (* 1/6 re) 1/2) (cos im))
0.0ms
im
@-inf
((* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (+ (* (+ (* 1/6 re) 1/2) re) 1) (* (exp re) (cos im)) (exp re) (- re -1) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (* re re) (+ (* 1/6 re) 1/2)) (* (exp re) (cos im)) (exp re) (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (* (exp re) (cos im)) (exp re) (+ (* (+ (* 1/2 re) 1) re) 1) (* (+ (* 1/2 re) 1) re) (+ (* 1/6 re) 1/2) (cos im))

simplify588.0ms (12.8%)

Memory
-131.3MiB live, 150.0MiB allocated; 734ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01811027
14861010
216831001
375931001
08104865
Stop Event
iter limit
node limit
Counts
64 → 64
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* re (+ 1/2 (* 1/6 re))))))
#s(approx (- re -1) #s(hole binary64 1))
#s(approx (- re -1) #s(hole binary64 (+ 1 re)))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* (pow re 2) (+ 1/2 (* 1/6 re)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* re (+ 1 (* 1/2 re)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* re (+ 1 (* re (+ 1/2 (* 1/6 re)))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 re))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* re (+ 1 (* 1/2 re)))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (+ 1/2 (* 1/6 re))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (+ (/ 1 (pow re 2)) (/ 1 (pow re 3))))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* 1/6 (pow re 2))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (- re -1) #s(hole binary64 re))
#s(approx (- re -1) #s(hole binary64 (* re (+ 1 (/ 1 re)))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))))))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* 1/6 re)))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* re (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))) re)) 1/6)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) #s(hole binary64 (cos im)))
Outputs
#s(approx (* (exp re) (cos im)) #s(hole binary64 (cos im)))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (cos im)))))
#s(approx (* (exp re) (cos im)) (fma.f64 (cos.f64 im) re (cos.f64 im)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* 1/2 (* re (cos im))))))))
#s(approx (* (exp re) (cos im)) (*.f64 (cos.f64 im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (cos im) (* re (+ (cos im) (* re (+ (* 1/6 (* re (cos im))) (* 1/2 (cos im)))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (*.f64 (cos.f64 im) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))) re (cos.f64 im)))
#s(approx (exp re) #s(hole binary64 1))
#s(approx (exp re) #s(literal 1 binary64))
#s(approx (exp re) #s(hole binary64 (+ 1 re)))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (exp re) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(literal 1 binary64))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (-.f64 re #s(literal -1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* re (+ 1/2 (* 1/6 re))))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(literal 1 binary64))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* 1/2 re))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (+ 1 (* re (+ 1/2 (* 1/6 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)))
#s(approx (- re -1) #s(hole binary64 1))
#s(approx (- re -1) #s(literal 1 binary64))
#s(approx (- re -1) #s(hole binary64 (+ 1 re)))
#s(approx (- re -1) (-.f64 re #s(literal -1 binary64)))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* (pow re 2) (+ 1/2 (* 1/6 re)))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) re)
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* re (+ 1 (* 1/2 re)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (fma.f64 (*.f64 #s(literal 1/2 binary64) re) re re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* re (+ 1 (* re (+ 1/2 (* 1/6 re)))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 1))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (-.f64 re #s(literal -1 binary64)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (+ 1 (* re (+ 1 (* 1/2 re))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 re))
#s(approx (* (+ (* 1/2 re) 1) re) re)
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* re (+ 1 (* 1/2 re)))))
#s(approx (* (+ (* 1/2 re) 1) re) (fma.f64 (*.f64 #s(literal 1/2 binary64) re) re re))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (+ 1/2 (* 1/6 re))))
#s(approx (+ (* 1/6 re) 1/2) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (* (cos im) (exp re))))
#s(approx (* (exp re) (cos im)) (*.f64 (cos.f64 im) (exp.f64 re)))
#s(approx (exp re) #s(hole binary64 (exp re)))
#s(approx (exp re) (exp.f64 re))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (+ (/ 1 (pow re 2)) (/ 1 (pow re 3))))))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* 1/6 (pow re 2))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64)))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)))
#s(approx (- re -1) #s(hole binary64 re))
#s(approx (- re -1) re)
#s(approx (- re -1) #s(hole binary64 (* re (+ 1 (/ 1 re)))))
#s(approx (- re -1) (-.f64 re #s(literal -1 binary64)))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (* (* re re) (+ (* 1/6 re) 1/2)) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* 1/6 (pow re 3))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* (pow re 3) (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* (pow re 3) (+ 1/6 (+ (* 1/2 (/ 1 re)) (/ 1 (pow re 2)))))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (fma.f64 (*.f64 #s(literal 1/2 binary64) re) re re))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(hole binary64 (* (pow re 2) (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))))))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* 1/2 (pow re 2))))
#s(approx (* (+ (* 1/2 re) 1) re) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))
#s(approx (* (+ (* 1/2 re) 1) re) #s(hole binary64 (* (pow re 2) (+ 1/2 (/ 1 re)))))
#s(approx (* (+ (* 1/2 re) 1) re) (fma.f64 (*.f64 #s(literal 1/2 binary64) re) re re))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* 1/6 re)))
#s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))
#s(approx (+ (* 1/6 re) 1/2) #s(hole binary64 (* re (+ 1/6 (* 1/2 (/ 1 re))))))
#s(approx (+ (* 1/6 re) 1/2) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (pow.f64 (neg.f64 re) #s(literal 3 binary64)) (-.f64 (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) re)) re) #s(literal 1/6 binary64))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (+ (/ 1 re) (/ 1 (pow re 2)))) re)) 1/6)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (pow.f64 (neg.f64 re) #s(literal 3 binary64)) (-.f64 (/.f64 (neg.f64 (-.f64 (/.f64 (/.f64 (-.f64 re #s(literal -1 binary64)) re) re) #s(literal -1/2 binary64))) re) #s(literal 1/6 binary64))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) #s(hole binary64 (* -1 (* (pow re 3) (- (* -1 (/ (+ 1/2 (/ 1 re)) re)) 1/6)))))
#s(approx (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) (*.f64 (pow.f64 (neg.f64 re) #s(literal 3 binary64)) (-.f64 (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 #s(literal 1 binary64) re)) re) #s(literal 1/6 binary64))))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (exp re)))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* -1/2 (* (pow im 2) (exp re))))))
#s(approx (* (exp re) (cos im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* 1/24 (* (pow im 2) (exp re))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (exp.f64 re)) (*.f64 im im) (exp.f64 re)))
#s(approx (* (exp re) (cos im)) #s(hole binary64 (+ (exp re) (* (pow im 2) (+ (* -1/2 (exp re)) (* (pow im 2) (+ (* -1/720 (* (pow im 2) (exp re))) (* 1/24 (exp re)))))))))
#s(approx (* (exp re) (cos im)) (fma.f64 (pow.f64 im #s(literal 4 binary64)) (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (exp.f64 re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)) (exp.f64 re))))
#s(approx (cos im) #s(hole binary64 1))
#s(approx (cos im) #s(literal 1 binary64))
#s(approx (cos im) #s(hole binary64 (+ 1 (* -1/2 (pow im 2)))))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* 1/24 (pow im 2)) 1/2)))))
#s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (+ 1 (* (pow im 2) (- (* (pow im 2) (+ 1/24 (* -1/720 (pow im 2)))) 1/2)))))
#s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))
#s(approx (cos im) #s(hole binary64 (cos im)))
#s(approx (cos im) (cos.f64 im))

rewrite98.0ms (2.1%)

Memory
3.0MiB live, 55.7MiB allocated; 12ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
046305
063305
1189305
01311302
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
21 → 181
Calls
Call 1
Inputs
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(-.f64 re #s(literal -1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
#s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))
Outputs
(*.f64 (cos.f64 im) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
(fma.f64 (*.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal -1 binary64)) #s(literal -1 binary64) #s(literal 1 binary64))
(fma.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(fma.f64 re (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 re (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal -1 binary64))))
(-.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))) re))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 re) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))))
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 3 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
(+.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re)))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))))
(/.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re)))
(fma.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal -1 binary64)) #s(literal -1 binary64) #s(literal 1 binary64))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 re #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64))
(fma.f64 re (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 re (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) #s(literal 1 binary64))
(-.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64))))
(-.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal -1 binary64))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) re))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))))
(+.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 1 binary64))
(+.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (exp re) (-.f64 re #s(literal -1 binary64)))
(/.f64 (neg.f64 (fma.f64 re re #s(literal -1 binary64))) (neg.f64 (+.f64 #s(literal -1 binary64) re)))
(/.f64 (neg.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 re re (fma.f64 #s(literal -1 binary64) re #s(literal 1 binary64)))))
(/.f64 (fma.f64 re re #s(literal -1 binary64)) (+.f64 #s(literal -1 binary64) re))
(/.f64 (-.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 re re (fma.f64 #s(literal -1 binary64) re #s(literal 1 binary64))))
(-.f64 (/.f64 (*.f64 re re) (+.f64 #s(literal -1 binary64) re)) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal -1 binary64) re)))
(-.f64 (/.f64 (pow.f64 re #s(literal 3 binary64)) (fma.f64 re re (fma.f64 #s(literal -1 binary64) re #s(literal 1 binary64)))) (/.f64 #s(literal -1 binary64) (fma.f64 re re (fma.f64 #s(literal -1 binary64) re #s(literal 1 binary64)))))
(-.f64 re #s(literal -1 binary64))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
(*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (neg.f64 re)) (neg.f64 re))
(*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (fabs.f64 re)) (fabs.f64 re))
(*.f64 (neg.f64 re) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(*.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))
(*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re)
(*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))
(*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 re re))
(*.f64 re (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re))
(/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))
(/.f64 (*.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64)) (*.f64 re re)) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64)))))
(/.f64 (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64))) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))
(/.f64 (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64))) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64)))))
(/.f64 (-.f64 (*.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64))) (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) re) re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))) (-.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re)))
(/.f64 (+.f64 (pow.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) #s(literal 3 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) re) re) #s(literal 3 binary64))) (fma.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (-.f64 (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) re) re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re)) (*.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re)))))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (neg.f64 re)) (neg.f64 re) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (fabs.f64 re)) (fabs.f64 re) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 (*.f64 (*.f64 re re) #s(literal 1/6 binary64)) re (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (*.f64 (*.f64 #s(literal 1/6 binary64) re) (neg.f64 re)) (neg.f64 re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (*.f64 (*.f64 #s(literal 1/6 binary64) re) (fabs.f64 re)) (fabs.f64 re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (*.f64 (*.f64 #s(literal 1/6 binary64) re) re) re (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) (*.f64 #s(literal 1/6 binary64) re)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) #s(literal 1/2 binary64)) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) #s(literal 1/2 binary64)) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) (*.f64 #s(literal 1/6 binary64) re)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (*.f64 #s(literal 1/2 binary64) re) re (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 (*.f64 re re) (*.f64 #s(literal 1/6 binary64) re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 (*.f64 re re) #s(literal 1/2 binary64) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 (*.f64 #s(literal 1/6 binary64) re) (*.f64 re re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 #s(literal 1/2 binary64) (*.f64 re re) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(fma.f64 #s(literal 1/6 binary64) (pow.f64 re #s(literal 3 binary64)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 re (*.f64 #s(literal 1/6 binary64) (*.f64 re re)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 re (*.f64 re (*.f64 #s(literal 1/6 binary64) re)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 re (*.f64 #s(literal 1/2 binary64) re) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
(-.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 #s(literal -1/2 binary64) (*.f64 re re)))
(-.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 (neg.f64 (*.f64 re re)) #s(literal 1/2 binary64)))
(+.f64 (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) re) re) (*.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/6 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(*.f64 (*.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal -1 binary64)) #s(literal -1 binary64))
(*.f64 (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64)))
(*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re)
(*.f64 #s(literal 1 binary64) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))
(*.f64 re (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) #s(literal 1 binary64)))
(*.f64 re (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)))
(/.f64 (*.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) re) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64)))
(/.f64 (*.f64 (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64)) re) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re)))
(/.f64 (*.f64 re (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64))) (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal -1 binary64)))
(/.f64 (*.f64 re (-.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 3 binary64)) #s(literal -1 binary64))) (-.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) #s(literal 2 binary64)) #s(literal 1 binary64)) (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re)))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (neg.f64 re)) (neg.f64 re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (neg.f64 re)) (neg.f64 re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (fabs.f64 re)) (fabs.f64 re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (fabs.f64 re)) (fabs.f64 re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re (*.f64 re #s(literal 1 binary64)))
(fma.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 re #s(literal 1 binary64)))
(fma.f64 #s(literal 1 binary64) re (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 re re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) (*.f64 re re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 re (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 re (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 re #s(literal 1 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
(+.f64 (*.f64 #s(literal 1 binary64) re) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
(+.f64 (*.f64 re #s(literal 1 binary64)) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))
(+.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re) (*.f64 #s(literal 1 binary64) re))
(+.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re) (*.f64 re #s(literal 1 binary64)))
(*.f64 #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))
#s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(*.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal -1 binary64)) #s(literal -1 binary64))
(*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re) #s(literal 1 binary64))
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) (*.f64 re #s(literal 1 binary64)))
(*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)
(*.f64 #s(literal 1 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))
(*.f64 re (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) #s(literal 1 binary64)))
(*.f64 re (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)))
(/.f64 (*.f64 (fma.f64 #s(literal 1/4 binary64) (*.f64 re re) #s(literal -1 binary64)) re) (fma.f64 #s(literal 1/2 binary64) re #s(literal -1 binary64)))
(/.f64 (*.f64 (fma.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64)) re) (fma.f64 #s(literal 1/4 binary64) (*.f64 re re) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re))))
(/.f64 (*.f64 re (fma.f64 #s(literal 1/4 binary64) (*.f64 re re) #s(literal -1 binary64))) (fma.f64 #s(literal 1/2 binary64) re #s(literal -1 binary64)))
(/.f64 (*.f64 re (fma.f64 (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64))) (fma.f64 #s(literal 1/4 binary64) (*.f64 re re) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) re))))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (neg.f64 re)) (neg.f64 re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (neg.f64 re)) (neg.f64 re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (fabs.f64 re)) (fabs.f64 re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (fabs.f64 re)) (fabs.f64 re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (neg.f64 re) (*.f64 (neg.f64 re) #s(literal 1/2 binary64)) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (fabs.f64 re) (*.f64 (fabs.f64 re) #s(literal 1/2 binary64)) (*.f64 re #s(literal 1 binary64)))
(fma.f64 (*.f64 #s(literal 1/2 binary64) re) re (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 #s(literal 1/2 binary64) re) re (*.f64 re #s(literal 1 binary64)))
(fma.f64 (*.f64 re re) #s(literal 1/2 binary64) (*.f64 #s(literal 1 binary64) re))
(fma.f64 (*.f64 re re) #s(literal 1/2 binary64) (*.f64 re #s(literal 1 binary64)))
(fma.f64 #s(literal 1 binary64) re (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(fma.f64 #s(literal 1/2 binary64) (*.f64 re re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 #s(literal 1/2 binary64) (*.f64 re re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 re (*.f64 #s(literal 1/2 binary64) re) (*.f64 #s(literal 1 binary64) re))
(fma.f64 re (*.f64 #s(literal 1/2 binary64) re) (*.f64 re #s(literal 1 binary64)))
(fma.f64 re #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(+.f64 (*.f64 #s(literal 1 binary64) re) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(+.f64 (*.f64 re #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 1/2 binary64) re) re))
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) re) re) (*.f64 #s(literal 1 binary64) re))
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) re) re) (*.f64 re #s(literal 1 binary64)))
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/36 binary64) (*.f64 re re))) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/6 binary64) re)))
(/.f64 (neg.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64))) (neg.f64 (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))
(/.f64 (neg.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64))) (neg.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64))))))
(/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))
(/.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (*.f64 re #s(literal 1/12 binary64)))))
(/.f64 (fma.f64 #s(literal 1/216 binary64) (pow.f64 re #s(literal 3 binary64)) #s(literal 1/8 binary64)) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64)))))
(fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))
(fma.f64 re #s(literal 1/6 binary64) #s(literal 1/2 binary64))
(-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/6 binary64) re))
(-.f64 #s(literal 1/2 binary64) (*.f64 (neg.f64 re) #s(literal 1/6 binary64)))
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 3 binary64)) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64))))) (/.f64 #s(literal 1/8 binary64) (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) (-.f64 #s(literal 1/4 binary64) (*.f64 re #s(literal 1/12 binary64))))))
(+.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/6 binary64) re))
#s(approx (cos im) (fma.f64 #s(literal -1/2 binary64) (*.f64 im im) #s(literal 1 binary64)))

eval38.0ms (0.8%)

Memory
6.8MiB live, 58.3MiB allocated; 10ms collecting garbage
Compiler

Compiled 9 273 to 1 241 computations (86.6% saved)

prune38.0ms (0.8%)

Memory
10.6MiB live, 56.8MiB allocated; 5ms collecting garbage
Pruning

29 alts after pruning (17 fresh and 12 done)

PrunedKeptTotal
New27913292
Fresh6410
Picked145
Done088
Total28629315
Accuracy
100.0%
Counts
315 → 29
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.9%
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
100.0%
(*.f64 (exp.f64 re) (cos.f64 im))
30.0%
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
61.8%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
33.6%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
58.0%
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
45.9%
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
12.1%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
15.6%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
12.3%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
7.2%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
24.9%
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
74.7%
#s(approx (* (exp re) (cos im)) (exp.f64 re))
45.2%
#s(approx (* (exp re) (cos im)) (cos.f64 im))
38.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
35.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
25.6%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
3.6%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
17.8%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
16.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
16.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
15.9%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
13.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
16.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
16.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
15.7%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
13.0%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
15.7%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
25.1%
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
Compiler

Compiled 1 670 to 673 computations (59.7% saved)

regimes75.0ms (1.6%)

Memory
-41.0MiB live, 103.7MiB allocated; 16ms collecting garbage
Counts
40 → 1
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 (exp.f64 re) (cos.f64 im))
(/.f64 (*.f64 (exp.f64 re) (pow.f64 (cos.f64 im) #s(literal 3 binary64))) (pow.f64 (cos.f64 im) #s(literal 2 binary64)))
(*.f64 (exp.f64 re) (/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 0 binary64) (sin.f64 im)) (-.f64 (*.f64 (*.f64 #s(literal 1 binary64) (cos.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im))) (*.f64 (*.f64 #s(literal 0 binary64) (sin.f64 im)) (*.f64 #s(literal 1 binary64) (cos.f64 im)))))))
Outputs
(*.f64 (exp.f64 re) (cos.f64 im))
Calls

5 calls:

28.0ms
im
14.0ms
(cos.f64 im)
12.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
10.0ms
re
8.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
100.0%1(cos.f64 im)
100.0%1(exp.f64 re)
100.0%1(*.f64 (exp.f64 re) (cos.f64 im))
100.0%1re
100.0%1im
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes60.0ms (1.3%)

Memory
29.3MiB live, 76.3MiB allocated; 2ms collecting garbage
Counts
37 → 4
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
Outputs
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
Calls

5 calls:

23.0ms
re
10.0ms
im
9.0ms
(cos.f64 im)
8.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
7.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
83.8%2(cos.f64 im)
94.9%3(exp.f64 re)
98.3%4(*.f64 (exp.f64 re) (cos.f64 im))
98.4%4re
84.5%2im
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes81.0ms (1.8%)

Memory
-14.1MiB live, 33.0MiB allocated; 2ms collecting garbage
Counts
36 → 5
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
Outputs
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
Calls

2 calls:

69.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
9.0ms
re
Results
AccuracySegmentsBranch
99.6%5(*.f64 (exp.f64 re) (cos.f64 im))
97.5%4re
Compiler

Compiled 6 to 7 computations (-16.7% saved)

regimes9.0ms (0.2%)

Memory
23.0MiB live, 23.0MiB allocated; 0ms collecting garbage
Counts
34 → 5
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
(*.f64 (exp.f64 re) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
Outputs
(*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64)))))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
Calls

1 calls:

7.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
99.5%5(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

regimes12.0ms (0.3%)

Memory
-22.6MiB live, 20.5MiB allocated; 6ms collecting garbage
Counts
32 → 5
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
(*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
Calls

1 calls:

10.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
99.2%5(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

regimes27.0ms (0.6%)

Memory
-22.6MiB live, 37.4MiB allocated; 16ms collecting garbage
Counts
31 → 5
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) (exp.f64 re))
Calls

2 calls:

18.0ms
re
7.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
94.5%3re
99.1%5(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 6 to 7 computations (-16.7% saved)

regimes57.0ms (1.2%)

Memory
16.7MiB live, 62.0MiB allocated; 4ms collecting garbage
Counts
30 → 3
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) (cos.f64 im))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
Calls

5 calls:

27.0ms
im
8.0ms
re
8.0ms
(cos.f64 im)
7.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
6.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
53.9%2(cos.f64 im)
51.8%2im
59.9%2re
59.9%2(exp.f64 re)
64.6%3(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes46.0ms (1%)

Memory
7.1MiB live, 51.8MiB allocated; 4ms collecting garbage
Counts
29 → 3
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/36 binary64) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64)))) re #s(literal 1 binary64)) re))))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))
Calls

5 calls:

15.0ms
(exp.f64 re)
8.0ms
im
7.0ms
re
7.0ms
(cos.f64 im)
6.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
38.0%1im
43.0%2(cos.f64 im)
39.9%2(exp.f64 re)
39.9%2re
44.9%3(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes7.0ms (0.2%)

Memory
7.0MiB live, 7.0MiB allocated; 0ms collecting garbage
Counts
25 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
Calls

1 calls:

6.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
43.0%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

regimes12.0ms (0.3%)

Memory
15.1MiB live, 15.1MiB allocated; 0ms collecting garbage
Counts
20 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
Outputs
(*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
Calls

2 calls:

5.0ms
(cos.f64 im)
5.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
42.5%2(cos.f64 im)
42.6%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 7 to 8 computations (-14.3% saved)

regimes61.0ms (1.3%)

Memory
-37.9MiB live, 8.9MiB allocated; 3ms collecting garbage
Counts
19 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
Calls

1 calls:

60.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
42.6%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

regimes11.0ms (0.2%)

Memory
25.1MiB live, 25.1MiB allocated; 0ms collecting garbage
Counts
18 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
Outputs
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
Calls

2 calls:

5.0ms
(cos.f64 im)
4.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
42.2%2(cos.f64 im)
42.3%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 7 to 8 computations (-14.3% saved)

regimes10.0ms (0.2%)

Memory
17.7MiB live, 17.7MiB allocated; 0ms collecting garbage
Counts
16 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
(*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(literal 1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
Outputs
(*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
Calls

2 calls:

4.0ms
(cos.f64 im)
4.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
40.4%2(cos.f64 im)
40.7%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 7 to 8 computations (-14.3% saved)

regimes41.0ms (0.9%)

Memory
-18.6MiB live, 34.0MiB allocated; 10ms collecting garbage
Counts
14 → 1
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
Calls

5 calls:

24.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
4.0ms
im
4.0ms
re
4.0ms
(cos.f64 im)
3.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
37.7%1im
37.7%1(exp.f64 re)
37.7%1re
37.7%1(cos.f64 im)
37.7%1(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes34.0ms (0.7%)

Memory
-3.7MiB live, 38.8MiB allocated; 9ms collecting garbage
Counts
13 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re)) re #s(literal 1 binary64)) re))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64))))))
Calls

5 calls:

19.0ms
re
4.0ms
im
4.0ms
(cos.f64 im)
3.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
3.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
35.0%1(cos.f64 im)
38.1%2(exp.f64 re)
38.1%2re
35.0%1im
38.1%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes4.0ms (0.1%)

Memory
7.6MiB live, 7.6MiB allocated; 0ms collecting garbage
Counts
10 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) (*.f64 #s(literal 1/6 binary64) re))))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re))))
Calls

1 calls:

3.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
38.1%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

regimes12.0ms (0.3%)

Memory
-20.7MiB live, 19.4MiB allocated; 8ms collecting garbage
Counts
8 → 1
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
Calls

3 calls:

6.0ms
(exp.f64 re)
3.0ms
re
2.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
35.0%1(exp.f64 re)
35.0%1re
35.0%1(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 8 to 10 computations (-25% saved)

regimes25.0ms (0.5%)

Memory
10.6MiB live, 56.4MiB allocated; 3ms collecting garbage
Counts
7 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (fma.f64 #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))))
Calls

5 calls:

6.0ms
re
5.0ms
im
4.0ms
(cos.f64 im)
4.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
3.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
35.1%2re
35.1%2(exp.f64 re)
28.5%2(cos.f64 im)
28.5%2im
35.2%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes4.0ms (0.1%)

Memory
5.0MiB live, 5.0MiB allocated; 0ms collecting garbage
Counts
5 → 2
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) #s(approx (+ (* 1/6 re) 1/2) #s(literal 1/2 binary64))))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))))
Calls

1 calls:

3.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
Results
AccuracySegmentsBranch
35.2%2(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 5 to 5 computations (0% saved)

regimes15.0ms (0.3%)

Memory
18.4MiB live, 18.4MiB allocated; 0ms collecting garbage
Counts
3 → 1
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
Calls

5 calls:

3.0ms
im
3.0ms
re
3.0ms
(cos.f64 im)
3.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
2.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
25.6%1(cos.f64 im)
25.6%1im
25.6%1(exp.f64 re)
25.6%1re
25.6%1(*.f64 (exp.f64 re) (cos.f64 im))
Compiler

Compiled 11 to 15 computations (-36.4% saved)

regimes19.0ms (0.4%)

Memory
-49.8MiB live, 16.6MiB allocated; 6ms collecting garbage
Counts
2 → 1
Calls
Call 1
Inputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (- re -1) re)))
Outputs
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
Calls

5 calls:

9.0ms
re
2.0ms
im
2.0ms
(cos.f64 im)
2.0ms
(*.f64 (exp.f64 re) (cos.f64 im))
2.0ms
(exp.f64 re)
Results
AccuracySegmentsBranch
25.1%1re
25.1%1(exp.f64 re)
25.1%1(*.f64 (exp.f64 re) (cos.f64 im))
25.1%1(cos.f64 im)
25.1%1im
Compiler

Compiled 11 to 15 computations (-36.4% saved)

bsearch67.0ms (1.5%)

Memory
26.2MiB live, 26.2MiB allocated; 0ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
narrow-enough
Steps
TimeLeftRight
17.0ms
1.5375427511102135e+100
1.0923650696131669e+105
27.0ms
3.9947925729479136e-16
0.8267010268873837
19.0ms
-0.14505011391745196
-0.0006665889547206646
Samples
39.0ms416×0valid
Compiler

Compiled 632 to 556 computations (12% saved)

Precisions
Click to see histograms. Total time spent on operations: 25.0ms
ival-cos: 14.0ms (56.4% of total)
ival-exp: 6.0ms (24.2% of total)
ival-mult: 4.0ms (16.1% of total)
ival-true: 0.0ms (0% of total)
adjust: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

bsearch1.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.9974424494263726
0.9999999964737424
0.0ms
0.0
0.12612326966170176
0.0ms
-0.06251694653043588
0.0
0.0ms
-inf
-0.9961296588310099
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch1.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.9974424494263726
0.9999999964737424
0.0ms
0.0
0.12612326966170176
0.0ms
-0.06251694653043588
0.0
0.0ms
-inf
-0.9961296588310099
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch1.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.9974424494263726
0.9999999964737424
0.0ms
0.0
0.12612326966170176
0.0ms
-0.06251694653043588
0.0
0.0ms
-inf
-0.9961296588310099
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch1.0ms (0%)

Memory
1.1MiB live, 1.1MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.9974424494263726
0.9999999964737424
0.0ms
0.0
0.12612326966170176
0.0ms
-0.06251694653043588
0.0
0.0ms
-inf
-0.9961296588310099
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.2857656090400047
+inf
0.0ms
-inf
-0.9961296588310099
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch1.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.2857656090400047
+inf
0.0ms
-0.06251694653043588
0.0
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.3MiB live, 0.4MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.06251694653043588
0.0
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.3MiB live, 0.2MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.0
0.12612326966170176
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.3MiB live, 0.3MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.0
0.12612326966170176
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.5MiB live, 0.5MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.0
0.12612326966170176
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.3MiB live, 0.3MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.0
0.12612326966170176
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.3MiB live, 0.3MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.2857656090400047
+inf
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.3MiB live, 0.3MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.2857656090400047
+inf
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
1.0
2.2857656090400047
Compiler

Compiled 8 to 10 computations (-25% saved)

bsearch0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.2857656090400047
+inf
Compiler

Compiled 8 to 10 computations (-25% saved)

simplify55.0ms (1.2%)

Memory
6.7MiB live, 51.6MiB allocated; 5ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01471133
11881091
22991091
36671091
424091091
Stop Event
node limit
Calls
Call 1
Inputs
(*.f64 (exp.f64 re) (cos.f64 im))
(if (<=.f64 re #s(literal -4496393867966703/576460752303423488 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 re #s(literal 8070450532247929/144115188075855872 binary64)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) (if (<=.f64 re #s(literal 10199999999999999144250989793269130915929985559700279936955770445581686411664085978843893938044698361856 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64))))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64))))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) #s(approx (* (exp re) (cos im)) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) #s(approx (* (exp re) (cos im)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 2 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))
Outputs
(*.f64 (exp.f64 re) (cos.f64 im))
(if (<=.f64 re #s(literal -4496393867966703/576460752303423488 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 re #s(literal 8070450532247929/144115188075855872 binary64)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) (if (<=.f64 re #s(literal 10199999999999999144250989793269130915929985559700279936955770445581686411664085978843893938044698361856 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)))))
(if (or (<=.f64 re #s(literal -4496393867966703/576460752303423488 binary64)) (not (or (<=.f64 re #s(literal 8070450532247929/144115188075855872 binary64)) (not (<=.f64 re #s(literal 10199999999999999144250989793269130915929985559700279936955770445581686411664085978843893938044698361856 binary64)))))) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64))))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64))))) (if (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (not (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (not (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)))))) (*.f64 #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64))))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 (exp.f64 re) #s(approx (cos im) #s(approx (+ (* (* im im) -1/2) 1) (*.f64 (*.f64 im im) #s(literal -1/2 binary64))))) (if (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (not (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (not (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)))))) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (not (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (not (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)))))) (*.f64 #s(approx (exp re) (+.f64 #s(literal 1 binary64) re)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) #s(approx (* (exp re) (cos im)) (cos.f64 im)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) #s(approx (* (exp re) (cos im)) (exp.f64 re)) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)) #s(approx (* (exp re) (cos im)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (not (or (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (not (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4494592428115755/4503599627370496 binary64)))))) #s(approx (* (exp re) (cos im)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) (exp.f64 re))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -inf.0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re))) #s(approx (cos im) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal -1/2 binary64)) (*.f64 im im) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) (cos.f64 im)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) (if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (/.f64 (*.f64 (fma.f64 #s(literal 1/36 binary64) (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 re re)) (-.f64 (*.f64 #s(literal 1/6 binary64) re) #s(literal 1/2 binary64))))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal -3602879701896397/72057594037927936 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64)))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) (-.f64 re #s(literal -1 binary64))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)) re #s(literal 1 binary64)) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) #s(approx (* (+ (* 1/2 re) 1) re) re))) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 0 binary64)) (*.f64 #s(approx (exp re) #s(literal 1 binary64)) #s(approx (cos im) (fma.f64 (*.f64 im im) #s(literal -1/2 binary64) #s(literal 1 binary64)))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re #s(literal 1 binary64))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 (*.f64 re re) (fma.f64 #s(literal 1/6 binary64) re #s(literal 1/2 binary64)))))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* (+ (* 1/6 re) 1/2) re) 1) re) 1) (*.f64 #s(approx (+ (* (+ (* 1/6 re) 1/2) re) 1) (*.f64 (*.f64 re re) #s(literal 1/6 binary64))) re)))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (fma.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re #s(literal 1 binary64))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 2 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (fma.f64 #s(literal 1/2 binary64) re #s(literal 1 binary64)) re)))))
(if (<=.f64 (*.f64 (exp.f64 re) (cos.f64 im)) #s(literal 4 binary64)) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64))) #s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(approx (+ (* (+ (* 1/2 re) 1) re) 1) (*.f64 (*.f64 re re) #s(literal 1/2 binary64))))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) (-.f64 re #s(literal -1 binary64))))
#s(approx (* (exp re) (cos im)) #s(approx (exp re) #s(literal 1 binary64)))

derivations0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated; 0ms collecting garbage

Profiling

Loading profile data...