math.cos on complex, imaginary part

Time bar (total: 6.8s)

start0.0ms (0%)

Memory
0.0MiB live, 0.0MiB 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 13 to 12 computations (7.7% saved)

sample2.5s (36.3%)

Memory
101.2MiB live, 2 515.3MiB allocated; 783ms collecting garbage
Samples
1.0s2 922×1valid
602.0ms1 209×2valid
389.0ms4 125×0valid
Precisions
Click to see histograms. Total time spent on operations: 1.7s
ival-exp: 685.0ms (39.4% of total)
ival-sin: 326.0ms (18.7% of total)
adjust: 285.0ms (16.4% of total)
ival-neg: 261.0ms (15% of total)
ival-mult!: 145.0ms (8.3% of total)
ival-sub!: 37.0ms (2.1% of total)
Bogosity

preprocess56.0ms (0.8%)

Memory
-30.7MiB live, 67.2MiB allocated; 10ms collecting garbage
Iterations

Useful iterations: 2 (0.0ms)

IterNodesCost
02668
18755
233634
3218734
Stop Event
node-limit
Alt Table
Click to see full alt table
StatusAccuracyProgram
67.4%
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Symmetry

(negabs re)

(negabs im)

Compiler

Compiled 20 to 20 computations (0% saved)

series11.0ms (0.2%)

Memory
-5.8MiB live, 40.6MiB allocated; 2ms collecting garbage
Counts
10 → 40
Calls
Call 1
Inputs
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
#s(literal 1/2 binary64)
(sin.f64 re)
re
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(exp.f64 (neg.f64 im))
(neg.f64 im)
im
(exp.f64 im)
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx re #s(hole binary64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx im #s(hole binary64 im))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
Calls

6 calls:

TimeVariablePointExpression
3.0ms
im
@-inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) 1/2 (sin re) re (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im))
2.0ms
im
@0
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) 1/2 (sin re) re (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im))
1.0ms
re
@inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) 1/2 (sin re) re (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im))
1.0ms
im
@inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) 1/2 (sin re) re (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im))
1.0ms
re
@-inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) 1/2 (sin re) re (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im))

rewrite249.0ms (3.7%)

Memory
41.9MiB live, 270.5MiB allocated; 157ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0194729
0204720
11154678
08283647
Stop Event
iter-limit
node-limit
iter-limit
Counts
50 → 97
Calls
Call 1
Inputs
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
#s(literal 1/2 binary64)
(sin.f64 re)
re
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(exp.f64 (neg.f64 im))
(neg.f64 im)
im
(exp.f64 im)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx re #s(hole binary64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx im #s(hole binary64 im))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
Outputs
(*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (sin.f64 re)) #s(literal 1/2 binary64))
(*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (*.f64 (sin.f64 re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
(*.f64 #s(literal 1/2 binary64) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (sin.f64 re)))
(neg.f64 (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
(*.f64 (sin.f64 re) #s(literal 1/2 binary64))
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
#s(literal 1/2 binary64)
(sin.f64 re)
re
(*.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
(*.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 (neg.f64 im) im))))))
(/.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (pow.f64 (neg.f64 (exp.f64 im)) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (-.f64 (exp.f64 (+.f64 im im)) (*.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im))))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))) (neg.f64 (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 (neg.f64 im) im))))))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (-.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im))))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 (neg.f64 im) im)))))
(/.f64 #s(literal 1 binary64) (/.f64 (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))))
(/.f64 #s(literal 1 binary64) (/.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 (neg.f64 im) im)))) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))))
(neg.f64 (-.f64 (neg.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 im))))
(neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))
(fma.f64 (pow.f64 (exp.f64 #s(literal -1 binary64)) (/.f64 im #s(literal 2 binary64))) (pow.f64 (exp.f64 #s(literal -1 binary64)) (/.f64 im #s(literal 2 binary64))) (neg.f64 (exp.f64 im)))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 (neg.f64 im) im))))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 (neg.f64 im) im))))))
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(+.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(*.f64 (pow.f64 (exp.f64 #s(literal -1 binary64)) (/.f64 im #s(literal 2 binary64))) (pow.f64 (exp.f64 #s(literal -1 binary64)) (/.f64 im #s(literal 2 binary64))))
(*.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)))
(pow.f64 (exp.f64 #s(literal -1 binary64)) im)
(pow.f64 (exp.f64 im) #s(literal -1 binary64))
(/.f64 (-.f64 (*.f64 (cosh.f64 im) (cosh.f64 im)) (*.f64 (sinh.f64 (neg.f64 im)) (sinh.f64 (neg.f64 im)))) (-.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im))))
(/.f64 (-.f64 (*.f64 (cosh.f64 im) (cosh.f64 im)) (*.f64 (sinh.f64 im) (sinh.f64 im))) (exp.f64 im))
(/.f64 (+.f64 (pow.f64 (cosh.f64 im) #s(literal 3 binary64)) (pow.f64 (sinh.f64 (neg.f64 im)) #s(literal 3 binary64))) (fma.f64 (cosh.f64 im) (cosh.f64 im) (-.f64 (*.f64 (sinh.f64 (neg.f64 im)) (sinh.f64 (neg.f64 im))) (*.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im))))))
(/.f64 (-.f64 (pow.f64 (cosh.f64 im) #s(literal 3 binary64)) (pow.f64 (sinh.f64 im) #s(literal 3 binary64))) (fma.f64 (cosh.f64 im) (cosh.f64 im) (fma.f64 (sinh.f64 im) (sinh.f64 im) (*.f64 (cosh.f64 im) (sinh.f64 im)))))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 im)))
(/.f64 #s(literal 1 binary64) (/.f64 (exp.f64 im) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (exp.f64 im))
(neg.f64 (/.f64 #s(literal -1 binary64) (exp.f64 im)))
(neg.f64 (-.f64 (sinh.f64 im) (cosh.f64 im)))
(neg.f64 (-.f64 (neg.f64 (cosh.f64 im)) (sinh.f64 (neg.f64 im))))
(-.f64 (cosh.f64 im) (sinh.f64 im))
(exp.f64 (-.f64 #s(literal 0 binary64) im))
(exp.f64 (*.f64 (log.f64 (exp.f64 #s(literal -1 binary64))) im))
(exp.f64 (neg.f64 im))
(+.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im)))
(*.f64 #s(literal -1 binary64) im)
(*.f64 im #s(literal -1 binary64))
(neg.f64 (neg.f64 (neg.f64 im)))
(neg.f64 im)
im
(/.f64 (-.f64 (*.f64 (cosh.f64 im) (cosh.f64 im)) (*.f64 (sinh.f64 im) (sinh.f64 im))) (exp.f64 (neg.f64 im)))
(/.f64 (+.f64 (pow.f64 (cosh.f64 im) #s(literal 3 binary64)) (pow.f64 (sinh.f64 im) #s(literal 3 binary64))) (fma.f64 (cosh.f64 im) (cosh.f64 im) (-.f64 (*.f64 (sinh.f64 im) (sinh.f64 im)) (*.f64 (cosh.f64 im) (sinh.f64 im)))))
(neg.f64 (-.f64 (neg.f64 (cosh.f64 im)) (sinh.f64 im)))
(exp.f64 im)
(+.f64 (cosh.f64 im) (sinh.f64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) #s(literal -1/12 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) #s(literal 1/240 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal -1/12 binary64))) (*.f64 re re)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) #s(literal -1/10080 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal 1/240 binary64))) (*.f64 re re)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal -1/12 binary64))) (*.f64 re re)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* 1/2 (sin re)) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (sin re) re)
#s(approx (sin re) (*.f64 (fma.f64 #s(literal -1/6 binary64) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 #s(literal 1/120 binary64) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/5040 binary64) (*.f64 re re) #s(literal 1/120 binary64)) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx re re)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (*.f64 (sin.f64 re) #s(literal 1/2 binary64))))
#s(approx (* 1/2 (sin re)) (*.f64 (sin.f64 re) #s(literal 1/2 binary64)))
#s(approx (sin re) (sin.f64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (-.f64 (*.f64 (*.f64 #s(literal -1/6 binary64) (*.f64 im im)) (sin.f64 re)) (sin.f64 re)) im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (-.f64 (*.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/120 binary64) (*.f64 (sin.f64 re) #s(literal -1/6 binary64))) (*.f64 im im)) (sin.f64 re)) im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/6 binary64) (sin.f64 re) (*.f64 (fma.f64 #s(literal -1/120 binary64) (sin.f64 re) (*.f64 (*.f64 #s(literal -1/5040 binary64) (*.f64 im im)) (sin.f64 re))) (*.f64 im im))) (*.f64 im im)) (sin.f64 re)) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 #s(literal -2 binary64) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(approx (exp (neg im)) (-.f64 #s(literal 1 binary64) im))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 im #s(literal 1/2 binary64) #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (neg im) (neg.f64 im))
#s(approx im im)
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (exp im) (-.f64 im #s(literal -1 binary64)))
#s(approx (exp im) (fma.f64 (fma.f64 im #s(literal 1/2 binary64) #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (- (exp (neg im)) (exp im)) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (exp im) (exp.f64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (*.f64 (sin.f64 re) #s(literal 1/2 binary64))))
#s(approx (- (exp (neg im)) (exp im)) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))

eval19.0ms (0.3%)

Memory
-24.1MiB live, 33.3MiB allocated; 14ms collecting garbage
Compiler

Compiled 870 to 399 computations (54.1% saved)

prune5.0ms (0.1%)

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

5 alts after pruning (5 fresh and 0 done)

PrunedKeptTotal
New80585
Fresh000
Picked101
Done000
Total81586
Accuracy
99.9%
Counts
86 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
15.4%
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
54.9%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
54.4%
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
64.7%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
50.0%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
Compiler

Compiled 154 to 152 computations (1.3% saved)

series47.0ms (0.7%)

Memory
7.7MiB live, 96.7MiB allocated; 18ms collecting garbage
Counts
35 → 121
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64))
(*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re)
(neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))
(*.f64 #s(literal 2 binary64) (sinh.f64 im))
#s(literal 2 binary64)
(sinh.f64 im)
im
re
#s(literal 1/2 binary64)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(exp.f64 (neg.f64 im))
(neg.f64 im)
(exp.f64 im)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 (neg.f64 im) (sin.f64 re))
(sin.f64 re)
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(*.f64 re re)
#s(literal -1/12 binary64)
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))
(exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))
(*.f64 (neg.f64 im) #s(literal 2 binary64))
(exp.f64 (+.f64 im im))
(+.f64 im im)
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* -1 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx re #s(hole binary64 re))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* 1/6 (* im (pow re 2)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* -1/120 (* im (pow re 2))) (* 1/6 im)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* 1/6 im) (* (pow re 2) (+ (* -1/120 im) (* 1/5040 (* im (pow re 2)))))))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* 1/2 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (+ 1/2 (* -1/12 (pow re 2)))))
#s(approx (* re re) #s(hole binary64 (pow re 2)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* re (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* -1/12 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/10080 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1/12 (pow re 3))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* (pow re 3) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* -1/12 (pow re 2))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1 (* (pow re 3) (- 1/12 (* 1/2 (/ 1 (pow re 2))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* -1/120 (* (pow im 2) re))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* (pow im 2) (+ (* -1/120 re) (* -1/5040 (* (pow im 2) re))))))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* -2 (* im re))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* im (+ (* -2 re) (* -1/3 (* (pow im 2) re))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* -1/60 (* (pow im 2) re))))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* (pow im 2) (+ (* -1/60 re) (* -1/2520 (* (pow im 2) re))))))))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* -2 im)))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* 2 im)))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* im (+ 2 (* 1/3 (pow im 2))))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* im (+ 2 (* (pow im 2) (+ 1/3 (* 1/60 (pow im 2))))))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* im (+ 2 (* (pow im 2) (+ 1/3 (* (pow im 2) (+ 1/60 (* 1/2520 (pow im 2))))))))))
#s(approx (sinh im) #s(hole binary64 im))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* 1/6 (pow im 2))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* 1/120 (pow im 2))))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* (pow im 2) (+ 1/120 (* 1/5040 (pow im 2))))))))))
#s(approx im #s(hole binary64 im))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* 1/2 (* (pow im 2) (- (* -4/3 (sin re)) (* -1 (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -8/315 (sin re)) (+ (* -1/360 (sin re)) (+ (* 1/24 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* -2 im)))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* -4 im)))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* im (- (* -8/3 (pow im 2)) 4))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -8/15 (pow im 2)) 8/3)) 4))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -16/315 (pow im 2)) 8/15)) 8/3)) 4))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 1))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (+ 1 (* -2 im))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (+ 1 (* im (- (* 2 im) 2)))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (+ 1 (* im (- (* im (+ 2 (* -4/3 im))) 2)))))
#s(approx (* (neg im) 2) #s(hole binary64 (* -2 im)))
#s(approx (exp (+ im im)) #s(hole binary64 1))
#s(approx (exp (+ im im)) #s(hole binary64 (+ 1 (* 2 im))))
#s(approx (exp (+ im im)) #s(hole binary64 (+ 1 (* im (+ 2 (* 2 im))))))
#s(approx (exp (+ im im)) #s(hole binary64 (+ 1 (* im (+ 2 (* im (+ 2 (* 4/3 im))))))))
#s(approx (+ im im) #s(hole binary64 (* 2 im)))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 2))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ 2 (pow im 2))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2)))))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2)))))))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (- (/ 1 (exp im)) (exp im))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (- (exp im) (/ 1 (exp im)))))
#s(approx (sinh im) #s(hole binary64 (* 1/2 (- (exp im) (/ 1 (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (- (exp (* -2 im)) (exp (* 2 im)))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (exp (* -2 im))))
#s(approx (exp (+ im im)) #s(hole binary64 (exp (* 2 im))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (neg im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (neg (* -2 im))))) (+ (exp im) (exp (* -1 im)))))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (exp (* -2 im)) (exp (neg (* -2 im)))) (+ (exp im) (exp (* -1 im))))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (- (exp (* -2 im)) (exp (neg (* -2 im))))))
#s(approx (exp (+ im im)) #s(hole binary64 (exp (neg (* -2 im)))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (* -1 im)))))
Calls

6 calls:

TimeVariablePointExpression
14.0ms
re
@0
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg (* 2 (sinh im))) re) (neg (* 2 (sinh im))) (* 2 (sinh im)) 2 (sinh im) im re 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (sin re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) -1/12 (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (- (exp (* (neg im) 2)) (exp (+ im im))) (exp (* (neg im) 2)) (* (neg im) 2) (exp (+ im im)) (+ im im) (+ (exp (neg im)) (exp im)))
11.0ms
im
@0
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg (* 2 (sinh im))) re) (neg (* 2 (sinh im))) (* 2 (sinh im)) 2 (sinh im) im re 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (sin re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) -1/12 (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (- (exp (* (neg im) 2)) (exp (+ im im))) (exp (* (neg im) 2)) (* (neg im) 2) (exp (+ im im)) (+ im im) (+ (exp (neg im)) (exp im)))
6.0ms
im
@inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg (* 2 (sinh im))) re) (neg (* 2 (sinh im))) (* 2 (sinh im)) 2 (sinh im) im re 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (sin re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) -1/12 (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (- (exp (* (neg im) 2)) (exp (+ im im))) (exp (* (neg im) 2)) (* (neg im) 2) (exp (+ im im)) (+ im im) (+ (exp (neg im)) (exp im)))
5.0ms
im
@-inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg (* 2 (sinh im))) re) (neg (* 2 (sinh im))) (* 2 (sinh im)) 2 (sinh im) im re 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (sin re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) -1/12 (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (- (exp (* (neg im) 2)) (exp (+ im im))) (exp (* (neg im) 2)) (* (neg im) 2) (exp (+ im im)) (+ im im) (+ (exp (neg im)) (exp im)))
5.0ms
re
@inf
((* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg (* 2 (sinh im))) re) (neg (* 2 (sinh im))) (* 2 (sinh im)) 2 (sinh im) im re 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (sin re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) -1/12 (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (- (exp (* (neg im) 2)) (exp (+ im im))) (exp (* (neg im) 2)) (* (neg im) 2) (exp (+ im im)) (+ im im) (+ (exp (neg im)) (exp im)))

rewrite221.0ms (3.3%)

Memory
-0.8MiB live, 324.5MiB allocated; 57ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
05562904
06042294
134302260
0111682136
Stop Event
iter-limit
node-limit
iter-limit
Counts
156 → 443
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64))
(*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re)
(neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))
(*.f64 #s(literal 2 binary64) (sinh.f64 im))
#s(literal 2 binary64)
(sinh.f64 im)
im
re
#s(literal 1/2 binary64)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(exp.f64 (neg.f64 im))
(neg.f64 im)
(exp.f64 im)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 (neg.f64 im) (sin.f64 re))
(sin.f64 re)
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(*.f64 re re)
#s(literal -1/12 binary64)
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))
(exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))
(*.f64 (neg.f64 im) #s(literal 2 binary64))
(exp.f64 (+.f64 im im))
(+.f64 im im)
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* -1 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx re #s(hole binary64 re))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* 1/6 (* im (pow re 2)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* -1/120 (* im (pow re 2))) (* 1/6 im)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* 1/6 im) (* (pow re 2) (+ (* -1/120 im) (* 1/5040 (* im (pow re 2)))))))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* 1/2 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (+ 1/2 (* -1/12 (pow re 2)))))
#s(approx (* re re) #s(hole binary64 (pow re 2)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* re (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* -1/12 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/10080 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1/12 (pow re 3))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* (pow re 3) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* -1/12 (pow re 2))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1 (* (pow re 3) (- 1/12 (* 1/2 (/ 1 (pow re 2))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* -1/120 (* (pow im 2) re))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* (pow im 2) (+ (* -1/120 re) (* -1/5040 (* (pow im 2) re))))))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* -2 (* im re))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* im (+ (* -2 re) (* -1/3 (* (pow im 2) re))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* -1/60 (* (pow im 2) re))))))))
#s(approx (* (neg (* 2 (sinh im))) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* (pow im 2) (+ (* -1/60 re) (* -1/2520 (* (pow im 2) re))))))))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* -2 im)))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* 2 im)))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* im (+ 2 (* 1/3 (pow im 2))))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* im (+ 2 (* (pow im 2) (+ 1/3 (* 1/60 (pow im 2))))))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (* im (+ 2 (* (pow im 2) (+ 1/3 (* (pow im 2) (+ 1/60 (* 1/2520 (pow im 2))))))))))
#s(approx (sinh im) #s(hole binary64 im))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* 1/6 (pow im 2))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* 1/120 (pow im 2))))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* (pow im 2) (+ 1/120 (* 1/5040 (pow im 2))))))))))
#s(approx im #s(hole binary64 im))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* 1/2 (* (pow im 2) (- (* -4/3 (sin re)) (* -1 (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -8/315 (sin re)) (+ (* -1/360 (sin re)) (+ (* 1/24 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* -2 im)))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* -4 im)))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* im (- (* -8/3 (pow im 2)) 4))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -8/15 (pow im 2)) 8/3)) 4))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -16/315 (pow im 2)) 8/15)) 8/3)) 4))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 1))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (+ 1 (* -2 im))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (+ 1 (* im (- (* 2 im) 2)))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (+ 1 (* im (- (* im (+ 2 (* -4/3 im))) 2)))))
#s(approx (* (neg im) 2) #s(hole binary64 (* -2 im)))
#s(approx (exp (+ im im)) #s(hole binary64 1))
#s(approx (exp (+ im im)) #s(hole binary64 (+ 1 (* 2 im))))
#s(approx (exp (+ im im)) #s(hole binary64 (+ 1 (* im (+ 2 (* 2 im))))))
#s(approx (exp (+ im im)) #s(hole binary64 (+ 1 (* im (+ 2 (* im (+ 2 (* 4/3 im))))))))
#s(approx (+ im im) #s(hole binary64 (* 2 im)))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 2))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ 2 (pow im 2))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2)))))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2)))))))))
#s(approx (neg (* 2 (sinh im))) #s(hole binary64 (- (/ 1 (exp im)) (exp im))))
#s(approx (* 2 (sinh im)) #s(hole binary64 (- (exp im) (/ 1 (exp im)))))
#s(approx (sinh im) #s(hole binary64 (* 1/2 (- (exp im) (/ 1 (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (- (exp (* -2 im)) (exp (* 2 im)))))
#s(approx (exp (* (neg im) 2)) #s(hole binary64 (exp (* -2 im))))
#s(approx (exp (+ im im)) #s(hole binary64 (exp (* 2 im))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (neg im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (neg (* -2 im))))) (+ (exp im) (exp (* -1 im)))))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (exp (* -2 im)) (exp (neg (* -2 im)))) (+ (exp im) (exp (* -1 im))))))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) #s(hole binary64 (- (exp (* -2 im)) (exp (neg (* -2 im))))))
#s(approx (exp (+ im im)) #s(hole binary64 (exp (neg (* -2 im)))))
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (* -1 im)))))
Outputs
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
(*.f64 #s(literal 1/4 binary64) (/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re) (cosh.f64 im)))
(*.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 re #s(literal 1/2 binary64)))
(*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re))
(/.f64 (neg.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(*.f64 (/.f64 re #s(literal 2 binary64)) (/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (cosh.f64 im)))
(*.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (/.f64 re (cosh.f64 im)))
(*.f64 (neg.f64 re) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re) (*.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (cosh.f64 im))))
(*.f64 #s(literal -1 binary64) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re))
(*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re) #s(literal -1 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re)
(*.f64 re (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(pow.f64 (/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re)) #s(literal -1 binary64))
(/.f64 (neg.f64 (neg.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re))) (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))
(/.f64 (neg.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re)) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 #s(literal -1 binary64) (neg.f64 (/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) re)))
(neg.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re))
(*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (cosh.f64 im))))
(*.f64 #s(literal -2 binary64) (sinh.f64 im))
(*.f64 #s(literal 1 binary64) (/.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (cosh.f64 im)))
(*.f64 #s(literal 2 binary64) (sinh.f64 (neg.f64 im)))
(pow.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) #s(literal -1 binary64))
(/.f64 (-.f64 (pow.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64)) (pow.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64))) (fma.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (fma.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))))
(/.f64 (-.f64 (*.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (exp.f64 (+.f64 im im)))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64)))) #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 3 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64)))) #s(literal 1 binary64)) (*.f64 (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im))))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(/.f64 (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))) (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 im)) (exp.f64 (neg.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 (neg.f64 im))) (exp.f64 im)))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))))
(neg.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(fma.f64 (/.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)) (/.f64 (exp.f64 (neg.f64 im)) (cosh.f64 im)) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(-.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(+.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(+.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(*.f64 (sinh.f64 im) #s(literal 2 binary64))
(*.f64 #s(literal 2 binary64) (*.f64 (sinh.f64 (/.f64 (+.f64 im im) #s(literal 2 binary64))) (cosh.f64 (/.f64 (-.f64 im im) #s(literal 2 binary64)))))
(*.f64 #s(literal 2 binary64) (sinh.f64 im))
(/.f64 (fma.f64 (sinh.f64 im) #s(literal 2 binary64) (*.f64 (sinh.f64 im) #s(literal 2 binary64))) #s(literal 2 binary64))
(/.f64 (fma.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))) #s(literal 4 binary64))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (+.f64 im im)) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im)))))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 (-.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64)))) (+.f64 (exp.f64 (+.f64 im im)) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im))))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(neg.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(-.f64 (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im)))))) (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im)))))))
(-.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(-.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))
(+.f64 (sinh.f64 im) (sinh.f64 im))
(+.f64 (exp.f64 im) (neg.f64 (exp.f64 (neg.f64 im))))
#s(literal 2 binary64)
(/.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal 2 binary64))
(/.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal -2 binary64))
(sinh.f64 im)
(-.f64 (/.f64 (exp.f64 im) #s(literal 2 binary64)) (/.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)))
(+.f64 (/.f64 (sinh.f64 im) #s(literal 2 binary64)) (/.f64 (sinh.f64 im) #s(literal 2 binary64)))
(+.f64 (/.f64 (exp.f64 im) #s(literal 2 binary64)) (/.f64 (neg.f64 (exp.f64 (neg.f64 im))) #s(literal 2 binary64)))
im
re
#s(literal 1/2 binary64)
(*.f64 (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
(*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (cosh.f64 im))))
(*.f64 #s(literal -2 binary64) (sinh.f64 im))
(*.f64 #s(literal 1 binary64) (/.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (cosh.f64 im)))
(*.f64 #s(literal 2 binary64) (sinh.f64 (neg.f64 im)))
(pow.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) #s(literal -1 binary64))
(/.f64 (-.f64 (pow.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64)) (pow.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64))) (fma.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (fma.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))))
(/.f64 (-.f64 (*.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (exp.f64 (+.f64 im im)))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64)))) #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 3 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64)))) #s(literal 1 binary64)) (*.f64 (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im))))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(/.f64 (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))) (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 im)) (exp.f64 (neg.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 (neg.f64 im))) (exp.f64 im)))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))))
(neg.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(fma.f64 (/.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)) (/.f64 (exp.f64 (neg.f64 im)) (cosh.f64 im)) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(-.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(+.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(+.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(*.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)))
(pow.f64 (exp.f64 (-.f64 im #s(literal 0 binary64))) #s(literal -1 binary64))
(pow.f64 (exp.f64 #s(literal -1 binary64)) im)
(pow.f64 (exp.f64 im) #s(literal -1 binary64))
(/.f64 (-.f64 (pow.f64 (cosh.f64 im) #s(literal 3 binary64)) (pow.f64 (sinh.f64 im) #s(literal 3 binary64))) (fma.f64 (cosh.f64 im) (cosh.f64 im) (fma.f64 (sinh.f64 im) (sinh.f64 im) (*.f64 (cosh.f64 im) (sinh.f64 im)))))
(/.f64 #s(literal -2 binary64) (*.f64 #s(literal 2 binary64) (neg.f64 (exp.f64 im))))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 im)))
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 (exp.f64 im))))
(/.f64 #s(literal 1 binary64) (pow.f64 (exp.f64 im) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (exp.f64 (-.f64 im #s(literal 0 binary64))))
(/.f64 #s(literal 1 binary64) (exp.f64 im))
(/.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (exp.f64 im)))
(-.f64 (cosh.f64 im) (sinh.f64 im))
(exp.f64 (+.f64 #s(literal 0 binary64) (neg.f64 im)))
(exp.f64 (-.f64 #s(literal 0 binary64) im))
(exp.f64 (*.f64 (log.f64 (exp.f64 #s(literal -1 binary64))) im))
(exp.f64 (*.f64 (log.f64 (exp.f64 im)) #s(literal -1 binary64)))
(exp.f64 (neg.f64 im))
(+.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im)))
(*.f64 #s(literal -1 binary64) im)
(*.f64 im #s(literal -1 binary64))
(neg.f64 im)
(exp.f64 im)
(+.f64 (cosh.f64 im) (sinh.f64 im))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 (*.f64 (sin.f64 re) im) #s(literal -1 binary64))
(*.f64 (neg.f64 im) (sin.f64 re))
(*.f64 #s(literal -1 binary64) (*.f64 (sin.f64 re) im))
(*.f64 (sin.f64 re) (neg.f64 im))
(neg.f64 (*.f64 (sin.f64 re) im))
(sin.f64 re)
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(*.f64 re (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)))
(fma.f64 re #s(literal 1/2 binary64) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 re #s(literal 1/2 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(fma.f64 #s(literal 1/2 binary64) re (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 #s(literal 1/2 binary64) re (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(+.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(+.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(/.f64 (-.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (fma.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/12 binary64) (*.f64 re re))))))
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))
(/.f64 (neg.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 re re) #s(literal 3 binary64)) #s(literal -1/1728 binary64) #s(literal 1/8 binary64))) (neg.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))))
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/4 binary64)) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64)))
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))))
(/.f64 (fma.f64 (pow.f64 (*.f64 re re) #s(literal 3 binary64)) #s(literal -1/1728 binary64) #s(literal 1/8 binary64)) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64)))))
(neg.f64 (-.f64 #s(literal -1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(neg.f64 (-.f64 (neg.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/2 binary64)))
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(fma.f64 #s(literal -1/12 binary64) (*.f64 re re) #s(literal 1/2 binary64))
(fma.f64 re (*.f64 re #s(literal -1/12 binary64)) #s(literal 1/2 binary64))
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (/.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/12 binary64) (*.f64 re re)))
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))) (/.f64 (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(+.f64 (/.f64 (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))))
(+.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))
(+.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))
(*.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)))
(*.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)))
(*.f64 (exp.f64 (log.f64 re)) (exp.f64 (log.f64 re)))
(*.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)))
(*.f64 (fabs.f64 re) (fabs.f64 re))
(*.f64 (neg.f64 re) (neg.f64 re))
(*.f64 re re)
(pow.f64 (exp.f64 (log.f64 re)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 re) #s(literal 2 binary64))
(pow.f64 (neg.f64 re) #s(literal 2 binary64))
(pow.f64 (*.f64 re re) #s(literal 1 binary64))
(pow.f64 re #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 re re)))
(fabs.f64 (*.f64 re re))
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))))
#s(literal -1/12 binary64)
(*.f64 (/.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) #s(literal 2 binary64)) (/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (cosh.f64 im)))
(*.f64 #s(literal 1/4 binary64) (/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (sin.f64 re)) (cosh.f64 im)))
(*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (sin.f64 re)) #s(literal 1/2 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 (sin.f64 re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (sin.f64 re)))
(/.f64 (neg.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (sin.f64 re)))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (neg.f64 (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (sin.f64 re))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(*.f64 (sin.f64 re) #s(literal 1/2 binary64))
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
(*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (cosh.f64 im))))
(*.f64 #s(literal -2 binary64) (sinh.f64 im))
(*.f64 #s(literal 1 binary64) (/.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (cosh.f64 im)))
(*.f64 #s(literal 2 binary64) (sinh.f64 (neg.f64 im)))
(pow.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) #s(literal -1 binary64))
(/.f64 (-.f64 (pow.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64)) (pow.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64))) (fma.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (fma.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))))
(/.f64 (-.f64 (*.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (exp.f64 (+.f64 im im)))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64)))) #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 3 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64)))) #s(literal 1 binary64)) (*.f64 (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im))))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(/.f64 (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))) (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 im)) (exp.f64 (neg.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 (neg.f64 im))) (exp.f64 im)))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))))
(neg.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(fma.f64 (/.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)) (/.f64 (exp.f64 (neg.f64 im)) (cosh.f64 im)) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(-.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(+.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(+.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im)))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 3 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im)))))))
(/.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64)))) (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im))))
(/.f64 (-.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 3 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im))))))
(neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))))
(fma.f64 (fabs.f64 (exp.f64 (neg.f64 im))) (fabs.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 (+.f64 im im))))
(fma.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 1 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 1 binary64)) (neg.f64 (exp.f64 (+.f64 im im))))
(fma.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 1 binary64)) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 (+.f64 im im))))
(fma.f64 (neg.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 (+.f64 im im))))
(fma.f64 #s(literal 1 binary64) (exp.f64 (*.f64 #s(literal -2 binary64) im)) (neg.f64 (exp.f64 (+.f64 im im))))
(fma.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 (+.f64 im im))))
(-.f64 (/.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im)))) (/.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im)))))
(-.f64 (/.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im)))))) (/.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (*.f64 #s(literal -2 binary64) im) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 #s(literal -2 binary64) im (+.f64 im im)))))))
(-.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im im)))
(+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (neg.f64 (exp.f64 (+.f64 im im))))
(*.f64 (fabs.f64 (exp.f64 (neg.f64 im))) (fabs.f64 (exp.f64 (neg.f64 im))))
(*.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 1 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 1 binary64)))
(*.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 1 binary64)) (exp.f64 (neg.f64 im)))
(*.f64 (neg.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 (neg.f64 im))))
(*.f64 #s(literal 1 binary64) (exp.f64 (*.f64 #s(literal -2 binary64) im)))
(*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im)))
(pow.f64 (*.f64 (exp.f64 #s(literal -1 binary64)) (exp.f64 #s(literal -1 binary64))) im)
(pow.f64 (exp.f64 #s(literal -1 binary64)) (+.f64 im im))
(pow.f64 (exp.f64 #s(literal 2 binary64)) (neg.f64 im))
(pow.f64 (exp.f64 #s(literal -2 binary64)) im)
(pow.f64 (exp.f64 (+.f64 im im)) #s(literal -1 binary64))
(pow.f64 (exp.f64 im) #s(literal -2 binary64))
(pow.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64))
(/.f64 #s(literal -1 binary64) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal -1 binary64) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 im)))
(/.f64 #s(literal -1 binary64) (*.f64 (exp.f64 (-.f64 im #s(literal 0 binary64))) (neg.f64 (exp.f64 im))))
(/.f64 #s(literal -1 binary64) (*.f64 (exp.f64 im) (neg.f64 (exp.f64 im))))
(/.f64 #s(literal 1 binary64) (*.f64 (exp.f64 (-.f64 im #s(literal 0 binary64))) (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal 1 binary64) (*.f64 (exp.f64 (-.f64 im #s(literal 0 binary64))) (exp.f64 im)))
(/.f64 #s(literal 1 binary64) (*.f64 (exp.f64 im) (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal 1 binary64) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal -2 binary64)))
(/.f64 #s(literal 1 binary64) (exp.f64 (+.f64 im im)))
(-.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (+.f64 im im)))
(exp.f64 (+.f64 (neg.f64 im) (neg.f64 im)))
(exp.f64 (*.f64 (log.f64 (exp.f64 #s(literal -2 binary64))) im))
(exp.f64 (*.f64 (log.f64 (exp.f64 (neg.f64 im))) #s(literal 2 binary64)))
(exp.f64 (*.f64 #s(literal -2 binary64) im))
(exp.f64 (neg.f64 (+.f64 im im)))
(+.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (neg.f64 (+.f64 im im))))
(+.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))
(*.f64 (neg.f64 im) #s(literal 2 binary64))
(*.f64 #s(literal 2 binary64) (neg.f64 im))
(neg.f64 (+.f64 im im))
(*.f64 (fabs.f64 (exp.f64 im)) (fabs.f64 (exp.f64 im)))
(*.f64 (neg.f64 (exp.f64 im)) (neg.f64 (exp.f64 im)))
(*.f64 (exp.f64 im) (exp.f64 im))
(pow.f64 (exp.f64 #s(literal 2 binary64)) im)
(pow.f64 (exp.f64 #s(literal -2 binary64)) (neg.f64 im))
(pow.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) #s(literal -1 binary64))
(pow.f64 (exp.f64 im) #s(literal 2 binary64))
(/.f64 (-.f64 (pow.f64 (cosh.f64 (+.f64 im im)) #s(literal 3 binary64)) (pow.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) #s(literal 3 binary64))) (fma.f64 (cosh.f64 (+.f64 im im)) (cosh.f64 (+.f64 im im)) (fma.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im))))
(/.f64 #s(literal 1 binary64) (exp.f64 (-.f64 (neg.f64 im) im)))
(/.f64 #s(literal 1 binary64) (exp.f64 (*.f64 #s(literal -2 binary64) im)))
(-.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (-.f64 (neg.f64 im) im)))
(-.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))
(exp.f64 (-.f64 #s(literal 0 binary64) (*.f64 #s(literal -2 binary64) im)))
(exp.f64 (*.f64 (log.f64 (exp.f64 #s(literal 2 binary64))) im))
(exp.f64 (+.f64 im im))
(+.f64 (cosh.f64 (+.f64 im im)) (sinh.f64 (+.f64 im im)))
(*.f64 #s(literal -2 binary64) (neg.f64 im))
(*.f64 #s(literal 2 binary64) im)
(*.f64 im #s(literal 2 binary64))
(/.f64 (neg.f64 (-.f64 (*.f64 im im) (*.f64 im im))) (neg.f64 (-.f64 im im)))
(/.f64 (neg.f64 (fma.f64 (*.f64 im im) im (*.f64 (*.f64 im im) im))) (neg.f64 (fma.f64 im im (-.f64 (*.f64 im im) (*.f64 im im)))))
(/.f64 (-.f64 (*.f64 im im) (*.f64 im im)) (-.f64 im im))
(/.f64 (fma.f64 (*.f64 im im) im (*.f64 (*.f64 im im) im)) (fma.f64 im im (-.f64 (*.f64 im im) (*.f64 im im))))
(neg.f64 (-.f64 (neg.f64 im) im))
(neg.f64 (*.f64 #s(literal -2 binary64) im))
(-.f64 (/.f64 (*.f64 im im) (-.f64 im im)) (/.f64 (*.f64 im im) (-.f64 im im)))
(+.f64 (/.f64 (*.f64 (*.f64 im im) im) (fma.f64 im im (-.f64 (*.f64 im im) (*.f64 im im)))) (/.f64 (*.f64 (*.f64 im im) im) (fma.f64 im im (-.f64 (*.f64 im im) (*.f64 im im)))))
(+.f64 im im)
(*.f64 #s(literal 2 binary64) (cosh.f64 im))
(/.f64 (neg.f64 (+.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im)))))))
(/.f64 (neg.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (expm1.f64 (+.f64 im im)))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(/.f64 (+.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64)))) (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im))))))
(/.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (expm1.f64 (+.f64 im im))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im)))) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
(neg.f64 (-.f64 (neg.f64 (exp.f64 im)) (exp.f64 (neg.f64 im))))
(neg.f64 (-.f64 (neg.f64 (exp.f64 (neg.f64 im))) (exp.f64 im)))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (exp.f64 im))
(-.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 (sinh.f64 im) #s(literal 2 binary64))) (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 (sinh.f64 im) #s(literal 2 binary64))))
(-.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
(+.f64 (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im)))))) (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (exp.f64 (+.f64 im (neg.f64 im)))))))
(+.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (expm1.f64 (+.f64 im im)))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (expm1.f64 (+.f64 im im)))))
(+.f64 (/.f64 (exp.f64 (*.f64 #s(literal -2 binary64) im)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
(+.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/240 binary64) (*.f64 re re)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 #s(literal -1/12 binary64) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/10080 binary64) (*.f64 re re)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 #s(literal 1/240 binary64) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/12 binary64) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re) #s(literal -1/2 binary64)))
#s(approx (* (neg (* 2 (sinh im))) re) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re))
#s(approx re re)
#s(approx (* 1/2 (sin re)) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (sin re) re)
#s(approx (sin re) (*.f64 (fma.f64 #s(literal -1/6 binary64) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 #s(literal 1/120 binary64) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/5040 binary64) (*.f64 re re) #s(literal 1/120 binary64)) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (* (neg im) (sin re)) (*.f64 (neg.f64 im) re))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal 1/5040 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal -1/120 binary64) im)) (*.f64 #s(literal 1/6 binary64) im)) (*.f64 re re) (neg.f64 im)) re))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(literal 1/2 binary64))
#s(approx (+ (* (* re re) -1/12) 1/2) (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)))
#s(approx (* re re) (*.f64 re re))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/240 binary64) (*.f64 re re)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 #s(literal -1/12 binary64) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/10080 binary64) (*.f64 re re)) (*.f64 #s(literal -2 binary64) (sinh.f64 im)) (*.f64 #s(literal 1/240 binary64) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/12 binary64) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
#s(approx (* 1/2 (sin re)) (*.f64 (sin.f64 re) #s(literal 1/2 binary64)))
#s(approx (sin re) (sin.f64 re))
#s(approx (* (neg im) (sin re)) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/12 binary64)) (*.f64 (*.f64 re re) re)))
#s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))
#s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/12 binary64)) (*.f64 re re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (neg.f64 re) (*.f64 re re)) (-.f64 #s(literal 1/12 binary64) (/.f64 #s(literal 1/2 binary64) (*.f64 re re)))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (*.f64 #s(literal -1/6 binary64) (*.f64 im im)) (sin.f64 re) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/120 binary64) (*.f64 (sin.f64 re) #s(literal -1/6 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) (sin.f64 re) (*.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/5040 binary64) (*.f64 (sin.f64 re) #s(literal -1/120 binary64))) (*.f64 im im))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/120 binary64) (*.f64 #s(literal -1/6 binary64) re)) (neg.f64 re)) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/5040 binary64) (*.f64 #s(literal -1/120 binary64) re)) (*.f64 #s(literal -1/6 binary64) re)) (*.f64 im im) (neg.f64 re)) im))
#s(approx (* (neg (* 2 (sinh im))) re) (*.f64 (*.f64 #s(literal -2 binary64) im) re))
#s(approx (* (neg (* 2 (sinh im))) re) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 (*.f64 im im) re) (*.f64 #s(literal -2 binary64) re)) im))
#s(approx (* (neg (* 2 (sinh im))) re) (*.f64 (fma.f64 (*.f64 im im) (fma.f64 #s(literal -1/60 binary64) (*.f64 (*.f64 im im) re) (*.f64 #s(literal -1/3 binary64) re)) (*.f64 #s(literal -2 binary64) re)) im))
#s(approx (* (neg (* 2 (sinh im))) re) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) (fma.f64 #s(literal -1/2520 binary64) (*.f64 (*.f64 im im) re) (*.f64 #s(literal -1/60 binary64) re)) (*.f64 #s(literal -1/3 binary64) re)) (*.f64 im im) (*.f64 #s(literal -2 binary64) re)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* 2 (sinh im)) (+.f64 im im))
#s(approx (* 2 (sinh im)) (*.f64 (fma.f64 #s(literal 1/3 binary64) (*.f64 im im) #s(literal 2 binary64)) im))
#s(approx (* 2 (sinh im)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/60 binary64) (*.f64 im im) #s(literal 1/3 binary64)) (*.f64 im im) #s(literal 2 binary64)) im))
#s(approx (* 2 (sinh im)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/2520 binary64) (*.f64 im im) #s(literal 1/60 binary64)) (*.f64 im im) #s(literal 1/3 binary64)) (*.f64 im im) #s(literal 2 binary64)) im))
#s(approx (sinh im) im)
#s(approx (sinh im) (*.f64 (fma.f64 (*.f64 im im) #s(literal 1/6 binary64) #s(literal 1 binary64)) im))
#s(approx (sinh im) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/120 binary64) #s(literal 1/6 binary64)) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx (sinh im) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/5040 binary64) #s(literal 1/120 binary64)) (*.f64 im im) #s(literal 1/6 binary64)) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx im im)
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(approx (exp (neg im)) (+.f64 (neg.f64 im) #s(literal 1 binary64)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 im #s(literal 1/2 binary64) #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (neg im) (neg.f64 im))
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (exp im) (+.f64 #s(literal 1 binary64) im))
#s(approx (exp im) (fma.f64 (fma.f64 im #s(literal 1/2 binary64) #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (fma.f64 (-.f64 (*.f64 (sin.f64 re) #s(literal -4/15 binary64)) (fma.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64) (*.f64 (sin.f64 re) #s(literal -1/12 binary64)))) (*.f64 im im) (*.f64 (sin.f64 re) #s(literal -1/3 binary64)))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (fma.f64 (-.f64 (*.f64 (sin.f64 re) #s(literal -8/315 binary64)) (fma.f64 #s(literal -1/360 binary64) (sin.f64 re) (fma.f64 #s(literal 1/2 binary64) (-.f64 (*.f64 (sin.f64 re) #s(literal -4/15 binary64)) (fma.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64) (*.f64 (sin.f64 re) #s(literal -1/12 binary64)))) (*.f64 #s(literal 1/24 binary64) (*.f64 (sin.f64 re) #s(literal -1/3 binary64)))))) (*.f64 im im) (-.f64 (*.f64 (sin.f64 re) #s(literal -4/15 binary64)) (fma.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64) (*.f64 (sin.f64 re) #s(literal -1/12 binary64)))))) (*.f64 im im) (*.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) (*.f64 #s(literal -4 binary64) im))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) (*.f64 (fma.f64 #s(literal -8/3 binary64) (*.f64 im im) #s(literal -4 binary64)) im))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) (*.f64 (fma.f64 (fma.f64 #s(literal -8/15 binary64) (*.f64 im im) #s(literal -8/3 binary64)) (*.f64 im im) #s(literal -4 binary64)) im))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -16/315 binary64) (*.f64 im im) #s(literal -8/15 binary64)) (*.f64 im im) #s(literal -8/3 binary64)) (*.f64 im im) #s(literal -4 binary64)) im))
#s(approx (exp (* (neg im) 2)) #s(literal 1 binary64))
#s(approx (exp (* (neg im) 2)) (fma.f64 #s(literal -2 binary64) im #s(literal 1 binary64)))
#s(approx (exp (* (neg im) 2)) (fma.f64 (fma.f64 #s(literal 2 binary64) im #s(literal -2 binary64)) im #s(literal 1 binary64)))
#s(approx (exp (* (neg im) 2)) (fma.f64 (fma.f64 (fma.f64 #s(literal -4/3 binary64) im #s(literal 2 binary64)) im #s(literal -2 binary64)) im #s(literal 1 binary64)))
#s(approx (* (neg im) 2) (*.f64 #s(literal -2 binary64) im))
#s(approx (exp (+ im im)) #s(literal 1 binary64))
#s(approx (exp (+ im im)) (fma.f64 #s(literal 2 binary64) im #s(literal 1 binary64)))
#s(approx (exp (+ im im)) (fma.f64 (fma.f64 #s(literal 2 binary64) im #s(literal 2 binary64)) im #s(literal 1 binary64)))
#s(approx (exp (+ im im)) (fma.f64 (fma.f64 (fma.f64 #s(literal 4/3 binary64) im #s(literal 2 binary64)) im #s(literal 2 binary64)) im #s(literal 1 binary64)))
#s(approx (+ im im) (+.f64 im im))
#s(approx (+ (exp (neg im)) (exp im)) #s(literal 2 binary64))
#s(approx (+ (exp (neg im)) (exp im)) (fma.f64 im im #s(literal 2 binary64)))
#s(approx (+ (exp (neg im)) (exp im)) (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/12 binary64) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64)))
#s(approx (+ (exp (neg im)) (exp im)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/360 binary64) (*.f64 im im) #s(literal 1/12 binary64)) (*.f64 im im) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64)))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
#s(approx (* 2 (sinh im)) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
#s(approx (sinh im) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal 1/2 binary64)))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (exp im) (exp.f64 im))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))
#s(approx (exp (* (neg im) 2)) (exp.f64 (*.f64 #s(literal -2 binary64) im)))
#s(approx (exp (+ im im)) (exp.f64 (+.f64 im im)))
#s(approx (+ (exp (neg im)) (exp im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 #s(literal -2 binary64) (sinh.f64 im))))
#s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 #s(literal -2 binary64) (sinh.f64 im)))
#s(approx (- (exp (* (neg im) 2)) (exp (+ im im))) (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 #s(literal -2 binary64) im))))
#s(approx (exp (+ im im)) (exp.f64 (+.f64 im im)))
#s(approx (+ (exp (neg im)) (exp im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))

eval43.0ms (0.6%)

Memory
5.9MiB live, 95.0MiB allocated; 13ms collecting garbage
Compiler

Compiled 4 105 to 1 885 computations (54.1% saved)

prune169.0ms (2.5%)

Memory
-30.9MiB live, 34.4MiB allocated; 240ms collecting garbage
Pruning

13 alts after pruning (12 fresh and 1 done)

PrunedKeptTotal
New40712419
Fresh000
Picked415
Done000
Total41113424
Accuracy
99.9%
Counts
424 → 13
Alt Table
Click to see full alt table
StatusAccuracyProgram
16.3%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
54.5%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
64.8%
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
21.7%
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
54.1%
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
64.7%
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
25.3%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
56.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
50.0%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
32.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
34.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
35.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
Compiler

Compiled 500 to 480 computations (4% saved)

series46.0ms (0.7%)

Memory
-16.0MiB live, 85.7MiB allocated; 14ms collecting garbage
Counts
34 → 111
Calls
Call 1
Inputs
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(literal -2 binary64) (sinh.f64 im))
#s(literal -2 binary64)
(sinh.f64 im)
im
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(*.f64 re re)
re
#s(literal -1/12 binary64)
#s(literal 1/2 binary64)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re))
(*.f64 (neg.f64 im) re)
(neg.f64 im)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im))
(*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)
(fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re))
(*.f64 (*.f64 im im) re)
(*.f64 im im)
#s(literal -1/6 binary64)
(neg.f64 re)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(literal 1 binary64)
(exp.f64 im)
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re)
Outputs
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* 1/12 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (* (pow re 2) (- (exp im) (/ 1 (exp im))))) (* 1/12 (- (exp im) (/ 1 (exp im))))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* 1/12 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (- (exp im) (/ 1 (exp im)))) (* 1/10080 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* 1/2 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (+ 1/2 (* -1/12 (pow re 2)))))
#s(approx (* re re) #s(hole binary64 (pow re 2)))
#s(approx re #s(hole binary64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (neg im) re) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* im (* re (- (* -1/6 (pow im 2)) 1)))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* re (- (* -1/6 (pow im 2)) 1))))
#s(approx (* (* im im) re) #s(hole binary64 (* (pow im 2) re)))
#s(approx (neg re) #s(hole binary64 (* -1 re)))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* re (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* -1/12 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/10080 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* -1 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* (sin re) (- (exp im) (/ 1 (exp im)))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1/12 (pow re 3))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* (pow re 3) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* -1/12 (pow re 2))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1 (* (pow re 3) (- 1/12 (* 1/2 (/ 1 (pow re 2))))))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1 (* im (* re (+ 1 (* 1/6 (pow im 2))))))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* -1 (* re (+ 1 (* 1/6 (pow im 2)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -2 im)))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (sinh im) #s(hole binary64 im))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* 1/6 (pow im 2))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* 1/120 (pow im 2))))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* (pow im 2) (+ 1/120 (* 1/5040 (pow im 2))))))))))
#s(approx im #s(hole binary64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* -1/120 (* (pow im 2) re))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* (pow im 2) (+ (* -1/120 re) (* -1/5040 (* (pow im 2) re))))))))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* -1 re)))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (- (* -1/6 (* (pow im 2) re)) re)))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* 1/2 (* (pow im 2) (- (* -4/3 (sin re)) (* -1 (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -8/315 (sin re)) (+ (* -1/360 (sin re)) (+ (* 1/24 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* -1/120 (* (pow im 2) re))))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* (pow im 2) (+ (* -1/120 re) (* -1/5040 (* (pow im 2) re))))))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* -2 (* im re))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* im (+ (* -2 re) (* -1/3 (* (pow im 2) re))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* -1/60 (* (pow im 2) re))))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* (pow im 2) (+ (* -1/60 re) (* -1/2520 (* (pow im 2) re))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -1 (- (exp im) (/ 1 (exp im))))))
#s(approx (sinh im) #s(hole binary64 (* 1/2 (- (exp im) (/ 1 (exp im))))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1/6 (* (pow im 3) re))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* (pow im 3) (+ (* -1 (/ re (pow im 2))) (* -1/6 re)))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* -1/6 (* (pow im 2) re))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* (pow im 2) (+ (* -1 (/ re (pow im 2))) (* -1/6 re)))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1 (* (pow im 3) (+ (* 1/6 re) (/ re (pow im 2)))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (neg (* -2 im))))) (+ (exp im) (exp (* -1 im)))))))
Calls

6 calls:

TimeVariablePointExpression
21.0ms
re
@inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) -2 (sinh im) im (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg im) re) (neg im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (+ (* (* (* im im) re) -1/6) (neg re)) (* (* im im) re) (* im im) -1/6 (neg re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* (* (* -2 (sinh im)) re) 1/2) (* (* -2 (sinh im)) re))
6.0ms
im
@-inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) -2 (sinh im) im (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg im) re) (neg im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (+ (* (* (* im im) re) -1/6) (neg re)) (* (* im im) re) (* im im) -1/6 (neg re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* (* (* -2 (sinh im)) re) 1/2) (* (* -2 (sinh im)) re))
5.0ms
re
@-inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) -2 (sinh im) im (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg im) re) (neg im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (+ (* (* (* im im) re) -1/6) (neg re)) (* (* im im) re) (* im im) -1/6 (neg re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* (* (* -2 (sinh im)) re) 1/2) (* (* -2 (sinh im)) re))
5.0ms
im
@inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) -2 (sinh im) im (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg im) re) (neg im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (+ (* (* (* im im) re) -1/6) (neg re)) (* (* im im) re) (* im im) -1/6 (neg re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* (* (* -2 (sinh im)) re) 1/2) (* (* -2 (sinh im)) re))
4.0ms
re
@0
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) -2 (sinh im) im (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (neg im) re) (neg im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (* (neg (* 2 (sinh im))) re) 1/2) (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (+ (* (* (* im im) re) -1/6) (neg re)) (* (* im im) re) (* im im) -1/6 (neg re) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (* (* (* -2 (sinh im)) re) 1/2) (* (* -2 (sinh im)) re))

rewrite169.0ms (2.5%)

Memory
37.2MiB live, 263.8MiB allocated; 25ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
05062933
05382432
129902432
095052327
Stop Event
iter-limit
node-limit
iter-limit
Counts
145 → 316
Calls
Call 1
Inputs
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(literal -2 binary64) (sinh.f64 im))
#s(literal -2 binary64)
(sinh.f64 im)
im
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(*.f64 re re)
re
#s(literal -1/12 binary64)
#s(literal 1/2 binary64)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re))
(*.f64 (neg.f64 im) re)
(neg.f64 im)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im))
(*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)
(fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re))
(*.f64 (*.f64 im im) re)
(*.f64 im im)
#s(literal -1/6 binary64)
(neg.f64 re)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(literal 1 binary64)
(exp.f64 im)
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re)
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* 1/12 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (* (pow re 2) (- (exp im) (/ 1 (exp im))))) (* 1/12 (- (exp im) (/ 1 (exp im))))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* 1/12 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (- (exp im) (/ 1 (exp im)))) (* 1/10080 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* 1/2 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (+ 1/2 (* -1/12 (pow re 2)))))
#s(approx (* re re) #s(hole binary64 (pow re 2)))
#s(approx re #s(hole binary64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (neg im) re) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* im (* re (- (* -1/6 (pow im 2)) 1)))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* re (- (* -1/6 (pow im 2)) 1))))
#s(approx (* (* im im) re) #s(hole binary64 (* (pow im 2) re)))
#s(approx (neg re) #s(hole binary64 (* -1 re)))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* re (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* -1/12 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* re (+ (* 1/2 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/12 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im))))) (* (pow re 2) (+ (* -1/10080 (/ (* (pow re 2) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im))))) (* 1/240 (/ (- (exp (* -2 im)) (exp (* 2 im))) (+ (exp im) (exp (neg im)))))))))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* -1 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* (sin re) (- (exp im) (/ 1 (exp im)))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1/12 (pow re 3))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* (pow re 3) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* -1/12 (pow re 2))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (* 2 im)))) (+ (exp im) (exp (neg im)))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1 (* (pow re 3) (- 1/12 (* 1/2 (/ 1 (pow re 2))))))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1 (* im (* re (+ 1 (* 1/6 (pow im 2))))))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* -1 (* re (+ 1 (* 1/6 (pow im 2)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -2 im)))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (sinh im) #s(hole binary64 im))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* 1/6 (pow im 2))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* 1/120 (pow im 2))))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* (pow im 2) (+ 1/120 (* 1/5040 (pow im 2))))))))))
#s(approx im #s(hole binary64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* -1/120 (* (pow im 2) re))))))))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* (pow im 2) (+ (* -1/120 re) (* -1/5040 (* (pow im 2) re))))))))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* -1 re)))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (- (* -1/6 (* (pow im 2) re)) re)))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* 1/2 (* (pow im 2) (- (* -4/3 (sin re)) (* -1 (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re))))))))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* -8/315 (sin re)) (+ (* -1/360 (sin re)) (+ (* 1/24 (- (* -4/3 (sin re)) (* -1 (sin re)))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))) (* 1/2 (- (* -4/15 (sin re)) (+ (* -1/12 (sin re)) (* 1/2 (- (* -4/3 (sin re)) (* -1 (sin re)))))))))))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* -1/6 (* (pow im 2) re))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* -1/120 (* (pow im 2) re))))))))
#s(approx (* (* (* -2 (sinh im)) re) 1/2) #s(hole binary64 (* im (+ (* -1 re) (* (pow im 2) (+ (* -1/6 re) (* (pow im 2) (+ (* -1/120 re) (* -1/5040 (* (pow im 2) re))))))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* -2 (* im re))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* im (+ (* -2 re) (* -1/3 (* (pow im 2) re))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* -1/60 (* (pow im 2) re))))))))
#s(approx (* (* -2 (sinh im)) re) #s(hole binary64 (* im (+ (* -2 re) (* (pow im 2) (+ (* -1/3 re) (* (pow im 2) (+ (* -1/60 re) (* -1/2520 (* (pow im 2) re))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -1 (- (exp im) (/ 1 (exp im))))))
#s(approx (sinh im) #s(hole binary64 (* 1/2 (- (exp im) (/ 1 (exp im))))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1/6 (* (pow im 3) re))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* (pow im 3) (+ (* -1 (/ re (pow im 2))) (* -1/6 re)))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* -1/6 (* (pow im 2) re))))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) #s(hole binary64 (* (pow im 2) (+ (* -1 (/ re (pow im 2))) (* -1/6 re)))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) #s(hole binary64 (* -1 (* (pow im 3) (+ (* 1/6 re) (/ re (pow im 2)))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (sin re) (- (exp (* -2 im)) (exp (neg (* -2 im))))) (+ (exp im) (exp (* -1 im)))))))
Outputs
(*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))
(*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))))
(*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) (*.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (cosh.f64 im))))
(*.f64 #s(literal -1 binary64) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal -1 binary64))
(*.f64 #s(literal 1 binary64) (/.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (cosh.f64 im)))
(*.f64 (sinh.f64 im) #s(literal -2 binary64))
(*.f64 #s(literal 2 binary64) (sinh.f64 (neg.f64 im)))
(*.f64 #s(literal -2 binary64) (sinh.f64 im))
(pow.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 im #s(literal -2 binary64))))) #s(literal -1 binary64))
(/.f64 (-.f64 (pow.f64 (/.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64)) (pow.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 3 binary64))) (fma.f64 (/.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (fma.f64 (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (/.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))))
(/.f64 (-.f64 (*.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (exp.f64 (+.f64 im im)))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 im #s(literal -2 binary64)) #s(literal 2 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64)))) #s(literal 1 binary64)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (-.f64 (exp.f64 (*.f64 (*.f64 im #s(literal -2 binary64)) #s(literal 3 binary64))) (exp.f64 (*.f64 (+.f64 im im) #s(literal 3 binary64)))) #s(literal 1 binary64)) (*.f64 (+.f64 (exp.f64 (*.f64 (*.f64 im #s(literal -2 binary64)) #s(literal 2 binary64))) (+.f64 (exp.f64 (*.f64 (+.f64 im im) #s(literal 2 binary64))) (exp.f64 (fma.f64 im #s(literal -2 binary64) (+.f64 im im))))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(/.f64 (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))))) (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 im)) (exp.f64 (neg.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (+.f64 im im))) (-.f64 (neg.f64 (exp.f64 (neg.f64 im))) (exp.f64 im)))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (+.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64))))
(/.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64))))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 #s(literal -1 binary64) (neg.f64 (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 im #s(literal -2 binary64)))))))
(/.f64 #s(literal 1 binary64) (*.f64 #s(literal 1 binary64) (/.f64 (cosh.f64 im) (sinh.f64 (*.f64 im #s(literal -2 binary64))))))
(neg.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(fma.f64 (/.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)) (/.f64 (exp.f64 (neg.f64 im)) (cosh.f64 im)) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (+.f64 (exp.f64 (+.f64 im im)) #s(literal 1 binary64)))))
(-.f64 (/.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
(+.f64 (/.f64 (exp.f64 (*.f64 im #s(literal -2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (/.f64 (neg.f64 (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(+.f64 (exp.f64 (neg.f64 im)) (neg.f64 (exp.f64 im)))
#s(literal -2 binary64)
(/.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal 2 binary64))
(/.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal -2 binary64))
(sinh.f64 im)
(-.f64 (/.f64 (exp.f64 im) #s(literal 2 binary64)) (/.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)))
(+.f64 (/.f64 (sinh.f64 im) #s(literal 2 binary64)) (/.f64 (sinh.f64 im) #s(literal 2 binary64)))
(+.f64 (/.f64 (exp.f64 im) #s(literal 2 binary64)) (/.f64 (neg.f64 (exp.f64 (neg.f64 im))) #s(literal 2 binary64)))
im
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(*.f64 re (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)))
(fma.f64 re #s(literal 1/2 binary64) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 re #s(literal 1/2 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(fma.f64 #s(literal 1/2 binary64) re (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 #s(literal 1/2 binary64) re (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(+.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(+.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(/.f64 (-.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (fma.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/12 binary64) (*.f64 re re))))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 re re) #s(literal 3 binary64)) #s(literal -1/1728 binary64) #s(literal 1/8 binary64))) (neg.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))))
(/.f64 (neg.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/4 binary64)) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64)))
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(/.f64 (fma.f64 (pow.f64 (*.f64 re re) #s(literal 3 binary64)) #s(literal -1/1728 binary64) #s(literal 1/8 binary64)) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64)))))
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))))
(neg.f64 (-.f64 (neg.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/2 binary64)))
(neg.f64 (-.f64 #s(literal -1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(fma.f64 #s(literal -1/12 binary64) (*.f64 re re) #s(literal 1/2 binary64))
(fma.f64 re (*.f64 re #s(literal -1/12 binary64)) #s(literal 1/2 binary64))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (/.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/12 binary64) (*.f64 re re)))
(+.f64 (/.f64 (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))))
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))) (/.f64 (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(+.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))
(+.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))
(*.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)))
(*.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)))
(*.f64 (exp.f64 (log.f64 re)) (exp.f64 (log.f64 re)))
(*.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)))
(*.f64 (fabs.f64 re) (fabs.f64 re))
(*.f64 (neg.f64 re) (neg.f64 re))
(*.f64 re re)
(pow.f64 (exp.f64 (log.f64 re)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 re) #s(literal 2 binary64))
(pow.f64 (neg.f64 re) #s(literal 2 binary64))
(pow.f64 (*.f64 re re) #s(literal 1 binary64))
(pow.f64 re #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 re re)))
(fabs.f64 (*.f64 re re))
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))))
re
#s(literal -1/12 binary64)
#s(literal 1/2 binary64)
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re))
(*.f64 (*.f64 re im) #s(literal -1 binary64))
(*.f64 #s(literal -1 binary64) (*.f64 re im))
(*.f64 (neg.f64 im) re)
(*.f64 re (neg.f64 im))
(neg.f64 (*.f64 re im))
(*.f64 #s(literal -1 binary64) im)
(*.f64 im #s(literal -1 binary64))
(neg.f64 im)
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re) im)))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re) im))
(*.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re) im)
(*.f64 im (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re))
(fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))
(fma.f64 im (neg.f64 re) (*.f64 im (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))
(+.f64 (*.f64 im (neg.f64 re)) (*.f64 im (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))
(+.f64 (*.f64 (neg.f64 re) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))
(/.f64 (-.f64 (*.f64 (neg.f64 re) (*.f64 re re)) (pow.f64 (*.f64 #s(literal 1/6 binary64) (*.f64 (*.f64 im im) re)) #s(literal 3 binary64))) (fma.f64 re re (fma.f64 (*.f64 #s(literal 1/6 binary64) (*.f64 (*.f64 im im) re)) (*.f64 #s(literal 1/6 binary64) (*.f64 (*.f64 im im) re)) (*.f64 (neg.f64 re) (*.f64 #s(literal 1/6 binary64) (*.f64 (*.f64 im im) re))))))
(/.f64 (neg.f64 (-.f64 (*.f64 re re) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))) (neg.f64 (-.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 re re))) (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 re re))) (neg.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) re)))
(/.f64 (neg.f64 (fma.f64 (neg.f64 re) (*.f64 re re) (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64)))) (neg.f64 (fma.f64 re re (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64) (*.f64 (neg.f64 re) (*.f64 re re)))) (neg.f64 (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (-.f64 (*.f64 re re) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))))))
(/.f64 (neg.f64 (-.f64 (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64)) (*.f64 (*.f64 re re) re))) (neg.f64 (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (fma.f64 re re (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re)))))
(/.f64 (-.f64 (*.f64 re re) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))) (-.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 re re)) (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re)))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 re re)) (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) re))
(/.f64 (fma.f64 (neg.f64 re) (*.f64 re re) (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64))) (fma.f64 re re (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))))
(/.f64 (fma.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64) (*.f64 (neg.f64 re) (*.f64 re re))) (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (-.f64 (*.f64 re re) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re)))))
(/.f64 (-.f64 (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64)) (*.f64 (*.f64 re re) re)) (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (fma.f64 re re (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re))))
(neg.f64 (-.f64 re (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))
(neg.f64 (-.f64 (neg.f64 (neg.f64 re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))))
(neg.f64 (-.f64 (neg.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (neg.f64 re)))
(fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re))
(fma.f64 (*.f64 (*.f64 im im) #s(literal -1/6 binary64)) re (neg.f64 re))
(fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re))
(fma.f64 #s(literal -1 binary64) re (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))
(fma.f64 #s(literal -1/6 binary64) (*.f64 (*.f64 im im) re) (neg.f64 re))
(fma.f64 re #s(literal -1 binary64) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))
(-.f64 (/.f64 (*.f64 re re) (-.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))) (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (-.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))) (/.f64 (*.f64 re re) (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) re)) (/.f64 (*.f64 re re) (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) re)))
(-.f64 (/.f64 (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64)) (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (fma.f64 re re (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re)))) (/.f64 (*.f64 (*.f64 re re) re) (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (fma.f64 re re (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re)))))
(-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re)
(-.f64 (neg.f64 re) (*.f64 #s(literal 1/6 binary64) (*.f64 (*.f64 im im) re)))
(+.f64 (/.f64 (*.f64 (neg.f64 re) (*.f64 re re)) (fma.f64 re re (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))))) (/.f64 (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64)) (fma.f64 re re (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) (*.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))))))
(+.f64 (/.f64 (*.f64 (pow.f64 (*.f64 (*.f64 im im) re) #s(literal 3 binary64)) #s(literal -1/216 binary64)) (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (-.f64 (*.f64 re re) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))))) (/.f64 (*.f64 (neg.f64 re) (*.f64 re re)) (fma.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (-.f64 (*.f64 re re) (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))))))
(+.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) (neg.f64 re))
(+.f64 (neg.f64 re) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))
(*.f64 (*.f64 im im) re)
(*.f64 re (*.f64 im im))
(*.f64 im (*.f64 re im))
(*.f64 (fabs.f64 (fabs.f64 im)) (fabs.f64 (fabs.f64 im)))
(*.f64 (neg.f64 (fabs.f64 im)) (neg.f64 (fabs.f64 im)))
(*.f64 (exp.f64 (log.f64 im)) (exp.f64 (log.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 (exp.f64 (log.f64 im)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 im) #s(literal 2 binary64))
(pow.f64 (*.f64 im im) #s(literal 1 binary64))
(pow.f64 (neg.f64 im) #s(literal 2 binary64))
(pow.f64 im #s(literal 2 binary64))
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (*.f64 im im)))
(fabs.f64 (*.f64 im im))
(exp.f64 (*.f64 (log.f64 im) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 im) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 im) #s(literal 2 binary64))))
#s(literal -1/6 binary64)
(*.f64 #s(literal -1 binary64) re)
(*.f64 re #s(literal -1 binary64))
(neg.f64 re)
(*.f64 (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)) (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(/.f64 (neg.f64 (-.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) (exp.f64 (+.f64 im im)))) (neg.f64 (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64))))) (neg.f64 (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (+.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))))
(/.f64 (-.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) (exp.f64 (+.f64 im im))) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(/.f64 (-.f64 (*.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64))) (exp.f64 (*.f64 im #s(literal 3 binary64)))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (+.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))))
(neg.f64 (-.f64 (exp.f64 im) #s(approx (exp (neg im)) #s(literal 1 binary64))))
(-.f64 (/.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) (/.f64 (exp.f64 (+.f64 im im)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(-.f64 (/.f64 (*.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (+.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))) (/.f64 (exp.f64 (*.f64 im #s(literal 3 binary64))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (+.f64 (exp.f64 (+.f64 im im)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))))
(-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))
(+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (neg.f64 (exp.f64 im)))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(literal 1 binary64)
(exp.f64 im)
(+.f64 (cosh.f64 im) (sinh.f64 im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re)) #s(literal 1/2 binary64)))
(*.f64 #s(literal 1/4 binary64) (/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re) (cosh.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re)) #s(literal 1/2 binary64))
(*.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))
(*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) (*.f64 re #s(literal 1/2 binary64)))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re)))
(/.f64 (neg.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re))) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(*.f64 (/.f64 re #s(literal 2 binary64)) (/.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) (cosh.f64 im)))
(*.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (/.f64 re (cosh.f64 im)))
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re) (*.f64 #s(literal 1/2 binary64) (/.f64 #s(literal 1 binary64) (cosh.f64 im))))
(*.f64 (neg.f64 re) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))
(*.f64 #s(literal -1 binary64) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re))
(*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re) #s(literal -1 binary64))
(*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) re)
(*.f64 re (*.f64 (sinh.f64 im) #s(literal -2 binary64)))
(*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re))
(pow.f64 (/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re)) #s(literal -1 binary64))
(/.f64 (neg.f64 (neg.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re))) (neg.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)))))
(/.f64 (neg.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re)) (neg.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im))))
(/.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))
(/.f64 #s(literal -1 binary64) (neg.f64 (/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re))))
(/.f64 #s(literal 1 binary64) (/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 (*.f64 im #s(literal -2 binary64)))) re)))
(neg.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re) #s(literal -1/2 binary64)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 (sinh.f64 im) #s(literal 2 binary64)) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal -1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/240 binary64) (*.f64 re re)) (*.f64 (sinh.f64 im) #s(literal 2 binary64)) (*.f64 #s(literal 1/12 binary64) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal -1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/10080 binary64) (*.f64 re re)) (*.f64 (sinh.f64 im) #s(literal 2 binary64)) (*.f64 #s(literal -1/240 binary64) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))) (*.f64 re re) (*.f64 #s(literal 1/12 binary64) (*.f64 (sinh.f64 im) #s(literal 2 binary64)))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal -1/2 binary64))) re))
#s(approx (* 1/2 (sin re)) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(literal 1/2 binary64))
#s(approx (+ (* (* re re) -1/12) 1/2) (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)))
#s(approx (* re re) (*.f64 re re))
#s(approx re re)
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re)) #s(literal 1/2 binary64)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 (*.f64 re re) (*.f64 (sinh.f64 im) #s(literal -2 binary64))) #s(literal -1/12 binary64) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal 1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) (*.f64 (sinh.f64 im) #s(literal -2 binary64))) #s(literal 1/240 binary64) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal -1/12 binary64))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal 1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) (*.f64 (sinh.f64 im) #s(literal -2 binary64))) #s(literal -1/10080 binary64) (*.f64 #s(literal 1/240 binary64) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal -1/12 binary64))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal 1/2 binary64))) re))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re) #s(literal -1/2 binary64)))
#s(approx (* (neg im) re) (*.f64 (neg.f64 im) re))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re) im))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re))
#s(approx (* (* im im) re) (*.f64 (*.f64 im im) re))
#s(approx (neg re) (neg.f64 re))
#s(approx (sin re) re)
#s(approx (sin re) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/6 binary64) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 #s(literal 1/120 binary64) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/5040 binary64) (*.f64 re re) #s(literal 1/120 binary64)) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re)) #s(literal 1/2 binary64)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 (*.f64 re re) (*.f64 (sinh.f64 im) #s(literal -2 binary64))) #s(literal -1/12 binary64) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal 1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) (*.f64 (sinh.f64 im) #s(literal -2 binary64))) #s(literal 1/240 binary64) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal -1/12 binary64))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal 1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) (*.f64 (sinh.f64 im) #s(literal -2 binary64))) #s(literal -1/10080 binary64) (*.f64 #s(literal 1/240 binary64) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal -1/12 binary64))) (*.f64 re re) (*.f64 (*.f64 (sinh.f64 im) #s(literal -2 binary64)) #s(literal 1/2 binary64))) re))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) re) #s(literal -1/2 binary64)))
#s(approx (* (* -2 (sinh im)) re) (*.f64 #s(literal -2 binary64) (*.f64 (sinh.f64 im) re)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) (sin.f64 re)) #s(literal -1/2 binary64)))
#s(approx (* 1/2 (sin re)) (*.f64 (sin.f64 re) #s(literal 1/2 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/12 binary64)) (*.f64 (*.f64 re re) re)))
#s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))
#s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/12 binary64)) (*.f64 re re)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 (sinh.f64 im) #s(literal -2 binary64))))
#s(approx (sin re) (sin.f64 re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 (sinh.f64 im) #s(literal -2 binary64))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (neg.f64 re) (*.f64 re re)) (-.f64 #s(literal 1/12 binary64) (/.f64 #s(literal 1/2 binary64) (*.f64 re re)))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (neg.f64 im) (*.f64 (fma.f64 #s(literal 1/6 binary64) (*.f64 im im) #s(literal 1 binary64)) re)))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (neg.f64 re) (fma.f64 #s(literal 1/6 binary64) (*.f64 im im) #s(literal 1 binary64))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/6 binary64) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/120 binary64) (*.f64 (sin.f64 re) #s(literal -1/6 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) (sin.f64 re) (*.f64 (fma.f64 #s(literal -1/120 binary64) (sin.f64 re) (*.f64 (*.f64 #s(literal -1/5040 binary64) (*.f64 im im)) (sin.f64 re))) (*.f64 im im))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* -2 (sinh im)) (*.f64 im #s(literal -2 binary64)))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (sinh im) im)
#s(approx (sinh im) (*.f64 (fma.f64 #s(literal 1/6 binary64) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx (sinh im) (*.f64 (fma.f64 (fma.f64 #s(literal 1/120 binary64) (*.f64 im im) #s(literal 1/6 binary64)) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx (sinh im) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/5040 binary64) (*.f64 im im) #s(literal 1/120 binary64)) (*.f64 im im) #s(literal 1/6 binary64)) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx im im)
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/6 binary64) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/120 binary64) (*.f64 (sin.f64 re) #s(literal -1/6 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) (sin.f64 re) (*.f64 (fma.f64 #s(literal -1/120 binary64) (sin.f64 re) (*.f64 (*.f64 #s(literal -1/5040 binary64) (*.f64 im im)) (sin.f64 re))) (*.f64 im im))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 im im) re) (*.f64 #s(literal -1/6 binary64) re)) (neg.f64 re)) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) (fma.f64 #s(literal -1/120 binary64) re (*.f64 #s(literal -1/5040 binary64) (*.f64 (*.f64 im im) re))) (*.f64 #s(literal -1/6 binary64) re)) (*.f64 im im) (neg.f64 re)) im))
#s(approx (neg im) (neg.f64 im))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (neg.f64 im) re))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re) im))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (neg.f64 re))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re))
#s(approx (* im im) (*.f64 im im))
#s(approx (* -2 (sinh im)) (*.f64 im #s(literal -2 binary64)))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(approx (exp (neg im)) (+.f64 #s(literal 1 binary64) (neg.f64 im)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (exp im) (+.f64 #s(literal 1 binary64) im))
#s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (fma.f64 (-.f64 (*.f64 (sin.f64 re) #s(literal -4/15 binary64)) (fma.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64) (*.f64 (sin.f64 re) #s(literal -1/12 binary64)))) (*.f64 im im) (*.f64 (sin.f64 re) #s(literal -1/3 binary64)))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (fma.f64 (-.f64 (*.f64 (sin.f64 re) #s(literal -8/315 binary64)) (fma.f64 #s(literal -1/360 binary64) (sin.f64 re) (fma.f64 #s(literal 1/2 binary64) (-.f64 (*.f64 (sin.f64 re) #s(literal -4/15 binary64)) (fma.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64) (*.f64 (sin.f64 re) #s(literal -1/12 binary64)))) (*.f64 #s(literal 1/24 binary64) (*.f64 (sin.f64 re) #s(literal -1/3 binary64)))))) (*.f64 im im) (-.f64 (*.f64 (sin.f64 re) #s(literal -4/15 binary64)) (fma.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64) (*.f64 (sin.f64 re) #s(literal -1/12 binary64)))))) (*.f64 im im) (*.f64 (*.f64 (sin.f64 re) #s(literal -1/3 binary64)) #s(literal 1/2 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) re) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 im im) re) (*.f64 #s(literal -1/6 binary64) re)) (neg.f64 re)) im))
#s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) (fma.f64 #s(literal -1/120 binary64) re (*.f64 #s(literal -1/5040 binary64) (*.f64 (*.f64 im im) re))) (*.f64 #s(literal -1/6 binary64) re)) (*.f64 im im) (neg.f64 re)) im))
#s(approx (* (* -2 (sinh im)) re) (*.f64 (*.f64 im #s(literal -2 binary64)) re))
#s(approx (* (* -2 (sinh im)) re) (*.f64 (fma.f64 (*.f64 #s(literal -1/3 binary64) (*.f64 im im)) re (*.f64 re #s(literal -2 binary64))) im))
#s(approx (* (* -2 (sinh im)) re) (*.f64 (fma.f64 (*.f64 im im) (fma.f64 (*.f64 #s(literal -1/60 binary64) (*.f64 im im)) re (*.f64 #s(literal -1/3 binary64) re)) (*.f64 re #s(literal -2 binary64))) im))
#s(approx (* (* -2 (sinh im)) re) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) (fma.f64 (*.f64 #s(literal -1/2520 binary64) (*.f64 im im)) re (*.f64 #s(literal -1/60 binary64) re)) (*.f64 #s(literal -1/3 binary64) re)) (*.f64 im im) (*.f64 re #s(literal -2 binary64))) im))
#s(approx (* -2 (sinh im)) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))
#s(approx (sinh im) (*.f64 (*.f64 (sinh.f64 im) #s(literal 2 binary64)) #s(literal 1/2 binary64)))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)))
#s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 im im)))
#s(approx (* -2 (sinh im)) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (exp im) (exp.f64 im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 (sinh.f64 im) #s(literal -2 binary64))))
#s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 im im) (neg.f64 im)) (fma.f64 #s(literal 1/6 binary64) re (/.f64 re (*.f64 im im)))))
#s(approx (* -2 (sinh im)) (*.f64 (sinh.f64 im) #s(literal -2 binary64)))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (sin.f64 re) #s(literal 1/2 binary64)) (*.f64 (sinh.f64 im) #s(literal -2 binary64))))

eval36.0ms (0.5%)

Memory
-29.9MiB live, 69.9MiB allocated; 13ms collecting garbage
Compiler

Compiled 3 604 to 1 476 computations (59% saved)

prune18.0ms (0.3%)

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

22 alts after pruning (19 fresh and 3 done)

PrunedKeptTotal
New29715312
Fresh347
Picked325
Done011
Total30322325
Accuracy
99.9%
Counts
325 → 22
Alt Table
Click to see full alt table
StatusAccuracyProgram
16.3%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
40.6%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
15.7%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
26.6%
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
34.8%
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
54.1%
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
57.8%
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
54.5%
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
64.7%
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
25.3%
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
56.5%
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
50.0%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
51.0%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
32.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
42.6%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
40.9%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
46.6%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
34.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
35.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
Compiler

Compiled 927 to 910 computations (1.8% saved)

series22.0ms (0.3%)

Memory
-2.3MiB live, 44.0MiB allocated; 2ms collecting garbage
Counts
35 → 97
Calls
Call 1
Inputs
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
(*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)
(fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64))
#s(literal -1/3 binary64)
(*.f64 im im)
im
#s(literal -2 binary64)
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(*.f64 re re)
re
#s(literal -1/12 binary64)
#s(literal 1/2 binary64)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re))
(*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)
(fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im))
(*.f64 (*.f64 re re) im)
#s(literal 1/6 binary64)
(neg.f64 im)
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(literal -2 binary64) #s(approx (sinh im) im))
#s(approx (sinh im) im)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))
(exp.f64 (neg.f64 im))
Outputs
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* 1/12 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (* (pow re 2) (- (exp im) (/ 1 (exp im))))) (* 1/12 (- (exp im) (/ 1 (exp im))))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* 1/12 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (- (exp im) (/ 1 (exp im)))) (* 1/10080 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* 1/2 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (+ 1/2 (* -1/12 (pow re 2)))))
#s(approx (* re re) #s(hole binary64 (pow re 2)))
#s(approx re #s(hole binary64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* 1/6 (* im (pow re 2)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* -1/120 (* im (pow re 2))) (* 1/6 im)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* 1/6 im) (* (pow re 2) (+ (* -1/120 im) (* 1/5040 (* im (pow re 2)))))))))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* re (+ (* -1 im) (* 1/6 (* im (pow re 2)))))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* -1 im)))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (- (* 1/6 (* im (pow re 2))) im)))
#s(approx (* (* re re) im) #s(hole binary64 (* im (pow re 2))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* (sin re) (- (exp im) (/ 1 (exp im)))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1/12 (pow re 3))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* (pow re 3) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* -1/12 (pow re 2))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* 1/6 (* im (pow re 3)))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* (pow re 3) (+ (* -1 (/ im (pow re 2))) (* 1/6 im)))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* 1/6 (* im (pow re 2)))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* (pow re 2) (+ (* -1 (/ im (pow re 2))) (* 1/6 im)))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1 (* (pow re 3) (- 1/12 (* 1/2 (/ 1 (pow re 2))))))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* -1 (* (pow re 3) (+ (* -1/6 im) (/ im (pow re 2)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -2 im)))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* -2 im)))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 -2))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 (- (* -1/3 (pow im 2)) 2)))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx im #s(hole binary64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* im (* re (- (* 1/6 (pow re 2)) 1)))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* im (- (* 1/6 (pow re 2)) 1))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx (sinh im) #s(hole binary64 im))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* 1/6 (pow im 2))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* 1/120 (pow im 2))))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* (pow im 2) (+ 1/120 (* 1/5040 (pow im 2))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -1 (- (exp im) (/ 1 (exp im))))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* -1/3 (pow im 3))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* -1 (* (pow im 3) (+ 1/3 (* 2 (/ 1 (pow im 2))))))))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 (* -1/3 (pow im 2))))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 (* -1 (* (pow im 2) (+ 1/3 (* 2 (/ 1 (pow im 2))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (sinh im) #s(hole binary64 (* 1/2 (- (exp im) (/ 1 (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* -1 (* im (* re (+ 1 (* -1/6 (pow re 2))))))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* -1 (* im (+ 1 (* -1/6 (pow re 2)))))))
Calls

6 calls:

TimeVariablePointExpression
4.0ms
im
@-inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (* (+ (* -1/3 (* im im)) -2) im) (+ (* -1/3 (* im im)) -2) -1/3 (* im im) im -2 (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (+ (* (* (* re re) im) 1/6) (neg im)) (* (* re re) im) 1/6 (neg im) (* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (sinh im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (- (exp (neg im)) (exp im)) (exp (neg im)))
4.0ms
im
@inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (* (+ (* -1/3 (* im im)) -2) im) (+ (* -1/3 (* im im)) -2) -1/3 (* im im) im -2 (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (+ (* (* (* re re) im) 1/6) (neg im)) (* (* re re) im) 1/6 (neg im) (* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (sinh im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (- (exp (neg im)) (exp im)) (exp (neg im)))
3.0ms
re
@0
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (* (+ (* -1/3 (* im im)) -2) im) (+ (* -1/3 (* im im)) -2) -1/3 (* im im) im -2 (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (+ (* (* (* re re) im) 1/6) (neg im)) (* (* re re) im) 1/6 (neg im) (* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (sinh im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (- (exp (neg im)) (exp im)) (exp (neg im)))
3.0ms
re
@inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (* (+ (* -1/3 (* im im)) -2) im) (+ (* -1/3 (* im im)) -2) -1/3 (* im im) im -2 (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (+ (* (* (* re re) im) 1/6) (neg im)) (* (* re re) im) 1/6 (neg im) (* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (sinh im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (- (exp (neg im)) (exp im)) (exp (neg im)))
3.0ms
re
@-inf
((* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (* (+ (* -1/3 (* im im)) -2) im) (+ (* -1/3 (* im im)) -2) -1/3 (* im im) im -2 (* 1/2 (sin re)) (* (+ (* (* re re) -1/12) 1/2) re) (+ (* (* re re) -1/12) 1/2) (* re re) re -1/12 1/2 (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* 1/2 (sin re)) (sin re) (- (exp (neg im)) (exp im)) (exp (neg im)) 1 (exp im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (* (neg im) (sin re)) (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (+ (* (* (* re re) im) 1/6) (neg im)) (* (* re re) im) 1/6 (neg im) (* (* -2 (sinh im)) (* 1/2 (sin re))) (* -2 (sinh im)) (sinh im) (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (- (exp (neg im)) (exp im)) (exp (neg im)))

rewrite165.0ms (2.4%)

Memory
1.1MiB live, 228.4MiB allocated; 28ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
03882100
04172037
121791981
087381904
Stop Event
iter-limit
node-limit
iter-limit
Counts
132 → 303
Calls
Call 1
Inputs
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im))
(*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)
(fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64))
#s(literal -1/3 binary64)
(*.f64 im im)
im
#s(literal -2 binary64)
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(*.f64 re re)
re
#s(literal -1/12 binary64)
#s(literal 1/2 binary64)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re))
(*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)
(fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im))
(*.f64 (*.f64 re re) im)
#s(literal 1/6 binary64)
(neg.f64 im)
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(literal -2 binary64) #s(approx (sinh im) im))
#s(approx (sinh im) im)
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))
(exp.f64 (neg.f64 im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* re (- (exp im) (/ 1 (exp im)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* 1/12 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (* (pow re 2) (- (exp im) (/ 1 (exp im))))) (* 1/12 (- (exp im) (/ 1 (exp im))))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* re (+ (* -1/2 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* 1/12 (- (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/240 (- (exp im) (/ 1 (exp im)))) (* 1/10080 (* (pow re 2) (- (exp im) (/ 1 (exp im)))))))))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 re)))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* 1/240 (pow re 2)) 1/12))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* re (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/240 (* -1/10080 (pow re 2)))) 1/12))))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* 1/2 re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* re (+ 1/2 (* -1/12 (pow re 2))))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 1/2))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (+ 1/2 (* -1/12 (pow re 2)))))
#s(approx (* re re) #s(hole binary64 (pow re 2)))
#s(approx re #s(hole binary64 re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* re (- (exp (neg im)) (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* -1/12 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/2 (- (exp (neg im)) (exp im)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* 1/240 (* (pow re 2) (- (exp (neg im)) (exp im))))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* re (+ (* 1/2 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/12 (- (exp (neg im)) (exp im))) (* (pow re 2) (+ (* -1/10080 (* (pow re 2) (- (exp (neg im)) (exp im)))) (* 1/240 (- (exp (neg im)) (exp im)))))))))))
#s(approx (sin re) #s(hole binary64 re))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* -1/6 (pow re 2))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* 1/120 (pow re 2)) 1/6))))))
#s(approx (sin re) #s(hole binary64 (* re (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/120 (* -1/5040 (pow re 2)))) 1/6))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* 1/6 (* im (pow re 2)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* -1/120 (* im (pow re 2))) (* 1/6 im)))))))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* re (+ (* -1 im) (* (pow re 2) (+ (* 1/6 im) (* (pow re 2) (+ (* -1/120 im) (* 1/5040 (* im (pow re 2)))))))))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* -1 (* im re))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* re (+ (* -1 im) (* 1/6 (* im (pow re 2)))))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* -1 im)))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (- (* 1/6 (* im (pow re 2))) im)))
#s(approx (* (* re re) im) #s(hole binary64 (* im (pow re 2))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1/2 (* (sin re) (- (exp im) (/ 1 (exp im)))))))
#s(approx (* 1/2 (sin re)) #s(hole binary64 (* 1/2 (sin re))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1/12 (pow re 3))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* (pow re 3) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* -1/12 (pow re 2))))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/12))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (neg im)) (exp im))))))
#s(approx (sin re) #s(hole binary64 (sin re)))
#s(approx (* (neg im) (sin re)) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* 1/6 (* im (pow re 3)))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* (pow re 3) (+ (* -1 (/ im (pow re 2))) (* 1/6 im)))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* 1/6 (* im (pow re 2)))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* (pow re 2) (+ (* -1 (/ im (pow re 2))) (* 1/6 im)))))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) #s(hole binary64 (* -1 (* (pow re 3) (- 1/12 (* 1/2 (/ 1 (pow re 2))))))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* -1 (* (pow re 3) (+ (* -1/6 im) (/ im (pow re 2)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -2 im)))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* -2 im)))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 -2))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 (- (* -1/3 (pow im 2)) 2)))
#s(approx (* im im) #s(hole binary64 (pow im 2)))
#s(approx im #s(hole binary64 im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* -1 (* im (sin re)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* -1/6 (* (pow im 2) (sin re)))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* -1/120 (* (pow im 2) (sin re)))))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* im (+ (* -1 (sin re)) (* (pow im 2) (+ (* -1/6 (sin re)) (* (pow im 2) (+ (* -1/120 (sin re)) (* -1/5040 (* (pow im 2) (sin re)))))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* -2 im)))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* -1/3 (pow im 2)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* -1/60 (pow im 2)) 1/3)) 2))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (* im (- (* (pow im 2) (- (* (pow im 2) (- (* -1/2520 (pow im 2)) 1/60)) 1/3)) 2))))
#s(approx (exp (neg im)) #s(hole binary64 1))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* -1 im))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* 1/2 im) 1)))))
#s(approx (exp (neg im)) #s(hole binary64 (+ 1 (* im (- (* im (+ 1/2 (* -1/6 im))) 1)))))
#s(approx (exp im) #s(hole binary64 1))
#s(approx (exp im) #s(hole binary64 (+ 1 im)))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* 1/2 im))))))
#s(approx (exp im) #s(hole binary64 (+ 1 (* im (+ 1 (* im (+ 1/2 (* 1/6 im))))))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* im (* re (- (* 1/6 (pow re 2)) 1)))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* im (- (* 1/6 (pow re 2)) 1))))
#s(approx (neg im) #s(hole binary64 (* -1 im)))
#s(approx (sinh im) #s(hole binary64 im))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* 1/6 (pow im 2))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* 1/120 (pow im 2))))))))
#s(approx (sinh im) #s(hole binary64 (* im (+ 1 (* (pow im 2) (+ 1/6 (* (pow im 2) (+ 1/120 (* 1/5040 (pow im 2))))))))))
#s(approx (* -2 (sinh im)) #s(hole binary64 (* -1 (- (exp im) (/ 1 (exp im))))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* -1/3 (pow im 3))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) #s(hole binary64 (* -1 (* (pow im 3) (+ 1/3 (* 2 (/ 1 (pow im 2))))))))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 (* -1/3 (pow im 2))))
#s(approx (+ (* -1/3 (* im im)) -2) #s(hole binary64 (* -1 (* (pow im 2) (+ 1/3 (* 2 (/ 1 (pow im 2))))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im))))
#s(approx (exp im) #s(hole binary64 (exp im)))
#s(approx (sinh im) #s(hole binary64 (* 1/2 (- (exp im) (/ 1 (exp im))))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (sin re) (- (exp (* -1 im)) (exp im))))))
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im))))
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) #s(hole binary64 (* -1 (* im (* re (+ 1 (* -1/6 (pow re 2))))))))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) #s(hole binary64 (* -1 (* im (+ 1 (* -1/6 (pow re 2)))))))
Outputs
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im))
(*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)
(*.f64 im (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)))
(/.f64 (+.f64 #s(literal -8 binary64) (pow.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 3 binary64))) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) (*.f64 #s(literal -2 binary64) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) #s(literal 4 binary64))) (neg.f64 (-.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) #s(literal 4 binary64))) (neg.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal 2 binary64))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 im im) #s(literal 3 binary64)) #s(literal -1/27 binary64) #s(literal -8 binary64))) (neg.f64 (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))))))
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 3 binary64)) #s(literal 8 binary64))) (neg.f64 (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (+.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 2 binary64))))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) #s(literal 4 binary64)) (-.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64)))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) #s(literal 4 binary64)) (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal 2 binary64)))
(/.f64 (fma.f64 (pow.f64 (*.f64 im im) #s(literal 3 binary64)) #s(literal -1/27 binary64) #s(literal -8 binary64)) (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64)))))
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 3 binary64)) #s(literal 8 binary64)) (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (+.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 2 binary64)))))
(neg.f64 (-.f64 #s(literal 2 binary64) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))))
(neg.f64 (-.f64 (neg.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) #s(literal -2 binary64)))
(fma.f64 (*.f64 #s(literal -1/3 binary64) im) im #s(literal -2 binary64))
(fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64))
(fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) (-.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))) (/.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal 2 binary64))) (/.f64 #s(literal 4 binary64) (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal 2 binary64))))
(-.f64 (/.f64 (pow.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 3 binary64)) (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (+.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 2 binary64))))) (/.f64 #s(literal 8 binary64) (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (+.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 2 binary64))))))
(-.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 2 binary64))
(+.f64 (/.f64 (pow.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal 3 binary64)) (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))))) (/.f64 #s(literal -8 binary64) (fma.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))))))
(+.f64 (*.f64 (*.f64 im im) #s(literal -1/3 binary64)) #s(literal -2 binary64))
(+.f64 #s(literal -2 binary64) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)))
#s(literal -1/3 binary64)
(*.f64 (fabs.f64 (fabs.f64 im)) (fabs.f64 (fabs.f64 im)))
(*.f64 (neg.f64 (fabs.f64 im)) (neg.f64 (fabs.f64 im)))
(*.f64 (exp.f64 (log.f64 im)) (exp.f64 (log.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 (exp.f64 (log.f64 im)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 im) #s(literal 2 binary64))
(pow.f64 (*.f64 im im) #s(literal 1 binary64))
(pow.f64 (neg.f64 im) #s(literal 2 binary64))
(pow.f64 im #s(literal 2 binary64))
(fabs.f64 (*.f64 im im))
(exp.f64 (*.f64 (log.f64 im) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 im) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 im) #s(literal 2 binary64))))
im
#s(literal -2 binary64)
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
(*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)
(*.f64 re (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)))
(/.f64 (+.f64 (pow.f64 (*.f64 re #s(literal 1/2 binary64)) #s(literal 3 binary64)) (pow.f64 (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 3 binary64))) (fma.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 re #s(literal 1/2 binary64)) (-.f64 (*.f64 (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (*.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(/.f64 (+.f64 (pow.f64 (*.f64 re #s(literal 1/2 binary64)) #s(literal 3 binary64)) (pow.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re) #s(literal 3 binary64))) (fma.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 re #s(literal 1/2 binary64)) (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re)) (*.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re)))))
(fma.f64 re #s(literal 1/2 binary64) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 re #s(literal 1/2 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(fma.f64 #s(literal 1/2 binary64) re (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(fma.f64 #s(literal 1/2 binary64) re (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(+.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 re (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(+.f64 (*.f64 re #s(literal 1/2 binary64)) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) re))
(/.f64 (-.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (fma.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/12 binary64) (*.f64 re re))))))
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))
(/.f64 (neg.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 re re) #s(literal 3 binary64)) #s(literal -1/1728 binary64) #s(literal 1/8 binary64))) (neg.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))))
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/4 binary64)) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64)))
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))))
(/.f64 (fma.f64 (pow.f64 (*.f64 re re) #s(literal 3 binary64)) #s(literal -1/1728 binary64) #s(literal 1/8 binary64)) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64)))))
(neg.f64 (-.f64 #s(literal -1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))))
(neg.f64 (-.f64 (neg.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) #s(literal 1/2 binary64)))
(fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64))
(fma.f64 #s(literal -1/12 binary64) (*.f64 re re) #s(literal 1/2 binary64))
(fma.f64 re (*.f64 re #s(literal -1/12 binary64)) #s(literal 1/2 binary64))
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))) (/.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (-.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/12 binary64) (*.f64 re re)))
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))) (/.f64 (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))))))
(+.f64 (/.f64 (pow.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 3 binary64)) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))))))
(+.f64 (*.f64 (*.f64 re re) #s(literal -1/12 binary64)) #s(literal 1/2 binary64))
(+.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))
(*.f64 (fabs.f64 (fabs.f64 re)) (fabs.f64 (fabs.f64 re)))
(*.f64 (neg.f64 (fabs.f64 re)) (neg.f64 (fabs.f64 re)))
(*.f64 (neg.f64 (neg.f64 re)) (neg.f64 (neg.f64 re)))
(*.f64 (exp.f64 (log.f64 re)) (exp.f64 (log.f64 re)))
(*.f64 (fabs.f64 re) (fabs.f64 re))
(*.f64 (neg.f64 re) (neg.f64 re))
(*.f64 re re)
(pow.f64 (exp.f64 (log.f64 re)) #s(literal 2 binary64))
(pow.f64 (fabs.f64 re) #s(literal 2 binary64))
(pow.f64 (neg.f64 re) #s(literal 2 binary64))
(pow.f64 (*.f64 re re) #s(literal 1 binary64))
(pow.f64 re #s(literal 2 binary64))
(fabs.f64 (*.f64 re re))
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64)))
(+.f64 (cosh.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))))
re
#s(literal -1/12 binary64)
#s(literal 1/2 binary64)
(*.f64 (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))))
(*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64))
(*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re))
#s(approx (sin re) re)
(/.f64 (fma.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64)) (pow.f64 (neg.f64 #s(approx (exp im) #s(literal 1 binary64))) #s(literal 3 binary64))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (-.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (neg.f64 #s(approx (exp im) #s(literal 1 binary64)))))))
(/.f64 (neg.f64 (-.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))) (neg.f64 (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64))) (*.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))) (neg.f64 (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))))))
(/.f64 (-.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
(/.f64 (-.f64 (*.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64))) (*.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64)))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))))
(neg.f64 (-.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))))
(-.f64 (/.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))) (/.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))))
(-.f64 (/.f64 (*.f64 (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64))) #s(approx (exp (neg im)) #s(literal 1 binary64))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))))) (/.f64 (*.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))) (fma.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp (neg im)) #s(literal 1 binary64)) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))))))
(-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))
(+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (neg.f64 #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(literal 1 binary64)
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im) re)))
#s(approx (* (neg im) (sin re)) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im) re))
(*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im) re)
(*.f64 re (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im))
(/.f64 (+.f64 (pow.f64 (*.f64 re (neg.f64 im)) #s(literal 3 binary64)) (pow.f64 (*.f64 re (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) #s(literal 3 binary64))) (fma.f64 (*.f64 re (neg.f64 im)) (*.f64 re (neg.f64 im)) (-.f64 (*.f64 (*.f64 re (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 re (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))) (*.f64 (*.f64 re (neg.f64 im)) (*.f64 re (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))))))
(/.f64 (+.f64 (pow.f64 (*.f64 (neg.f64 im) re) #s(literal 3 binary64)) (pow.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re) #s(literal 3 binary64))) (fma.f64 (*.f64 (neg.f64 im) re) (*.f64 (neg.f64 im) re) (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re)) (*.f64 (*.f64 (neg.f64 im) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re)))))
(fma.f64 (neg.f64 im) re (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re))
(fma.f64 (*.f64 re im) #s(literal -1 binary64) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re))
(fma.f64 #s(literal -1 binary64) (*.f64 re im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re))
(fma.f64 re (neg.f64 im) (*.f64 re (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))
(+.f64 (*.f64 re (neg.f64 im)) (*.f64 re (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))
(+.f64 (*.f64 (neg.f64 im) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) re))
(/.f64 (-.f64 (*.f64 (*.f64 im im) (neg.f64 im)) (pow.f64 (*.f64 #s(literal -1/6 binary64) (*.f64 (*.f64 re re) im)) #s(literal 3 binary64))) (fma.f64 im im (fma.f64 (*.f64 #s(literal -1/6 binary64) (*.f64 (*.f64 re re) im)) (*.f64 #s(literal -1/6 binary64) (*.f64 (*.f64 re re) im)) (*.f64 (neg.f64 im) (*.f64 #s(literal -1/6 binary64) (*.f64 (*.f64 re re) im))))))
(/.f64 (neg.f64 (-.f64 (*.f64 im im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))) (neg.f64 (-.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 im im))) (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))))
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 im im))) (neg.f64 (fma.f64 (*.f64 #s(literal 1/6 binary64) im) (*.f64 re re) im)))
(/.f64 (neg.f64 (fma.f64 (*.f64 im im) (neg.f64 im) (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64)))) (neg.f64 (fma.f64 im im (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))))))
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64) (*.f64 (*.f64 im im) (neg.f64 im)))) (neg.f64 (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (-.f64 (*.f64 im im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))))))
(/.f64 (neg.f64 (-.f64 (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64)) (*.f64 (*.f64 im im) im))) (neg.f64 (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (fma.f64 im im (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im)))))
(/.f64 (-.f64 (*.f64 im im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))) (-.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 im im)) (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im)))
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 im im)) (fma.f64 (*.f64 #s(literal 1/6 binary64) im) (*.f64 re re) im))
(/.f64 (fma.f64 (*.f64 im im) (neg.f64 im) (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64))) (fma.f64 im im (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))))
(/.f64 (fma.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64) (*.f64 (*.f64 im im) (neg.f64 im))) (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (-.f64 (*.f64 im im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im)))))
(/.f64 (-.f64 (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64)) (*.f64 (*.f64 im im) im)) (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (fma.f64 im im (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im))))
(neg.f64 (-.f64 im (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))
(neg.f64 (-.f64 (neg.f64 (neg.f64 im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))))
(neg.f64 (-.f64 (neg.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (neg.f64 im)))
(fma.f64 (*.f64 #s(literal 1/6 binary64) im) (*.f64 re re) (neg.f64 im))
(fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im))
(fma.f64 #s(literal -1 binary64) im (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))
(fma.f64 (*.f64 re re) (*.f64 #s(literal 1/6 binary64) im) (neg.f64 im))
(fma.f64 #s(literal 1/6 binary64) (*.f64 (*.f64 re re) im) (neg.f64 im))
(fma.f64 im #s(literal -1 binary64) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))
(-.f64 (/.f64 (*.f64 im im) (-.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))) (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (-.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))) (/.f64 (*.f64 im im) (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))))
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (fma.f64 (*.f64 #s(literal 1/6 binary64) im) (*.f64 re re) im)) (/.f64 (*.f64 im im) (fma.f64 (*.f64 #s(literal 1/6 binary64) im) (*.f64 re re) im)))
(-.f64 (/.f64 (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64)) (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (fma.f64 im im (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im)))) (/.f64 (*.f64 (*.f64 im im) im) (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (fma.f64 im im (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im)))))
(-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im)
(-.f64 (neg.f64 im) (*.f64 #s(literal -1/6 binary64) (*.f64 (*.f64 re re) im)))
(+.f64 (/.f64 (*.f64 (*.f64 im im) (neg.f64 im)) (fma.f64 im im (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))))) (/.f64 (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64)) (fma.f64 im im (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) (*.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))))))
(+.f64 (/.f64 (*.f64 (pow.f64 (*.f64 (*.f64 re re) im) #s(literal 3 binary64)) #s(literal 1/216 binary64)) (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (-.f64 (*.f64 im im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))))) (/.f64 (*.f64 (*.f64 im im) (neg.f64 im)) (fma.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (-.f64 (*.f64 im im) (*.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))))))
(+.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) (neg.f64 im))
(+.f64 (neg.f64 im) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))
(*.f64 (*.f64 re re) im)
(*.f64 re (*.f64 re im))
(*.f64 im (*.f64 re re))
#s(literal 1/6 binary64)
(*.f64 #s(literal -1 binary64) im)
(*.f64 im #s(literal -1 binary64))
(neg.f64 im)
(*.f64 (*.f64 #s(approx (sinh im) im) #s(literal -2 binary64)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (*.f64 #s(approx (sinh im) im) #s(literal -2 binary64)))
(*.f64 #s(literal -2 binary64) (*.f64 #s(approx (sinh im) im) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))))
(*.f64 #s(approx (sinh im) im) #s(literal -2 binary64))
(*.f64 #s(literal -2 binary64) #s(approx (sinh im) im))
#s(approx (sinh im) im)
(*.f64 (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))) (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(approx (sin re) re) #s(literal 1/2 binary64)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))))
(/.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (pow.f64 (neg.f64 #s(approx (exp im) #s(literal 1 binary64))) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (-.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) (*.f64 (exp.f64 (neg.f64 im)) (neg.f64 #s(approx (exp im) #s(literal 1 binary64)))))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))) (neg.f64 (+.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))))
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (*.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))) (neg.f64 (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))))))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)))) (+.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (*.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64)))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))))
(neg.f64 (-.f64 #s(approx (exp im) #s(literal 1 binary64)) (exp.f64 (neg.f64 im))))
(fma.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)) (neg.f64 #s(approx (exp im) #s(literal 1 binary64))))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))) (/.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) (+.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))))
(-.f64 (/.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 3 binary64))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))))) (/.f64 (*.f64 (*.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (fma.f64 #s(approx (exp im) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64)) (*.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))))))
(-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64)))
(+.f64 (exp.f64 (neg.f64 im)) (neg.f64 #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1 binary64) (exp.f64 (neg.f64 im)))
(pow.f64 (exp.f64 (-.f64 im #s(literal 0 binary64))) #s(literal -1 binary64))
(pow.f64 (exp.f64 #s(literal -1 binary64)) im)
(pow.f64 (exp.f64 im) #s(literal -1 binary64))
(/.f64 (+.f64 (pow.f64 (cosh.f64 im) #s(literal 3 binary64)) (pow.f64 (sinh.f64 (neg.f64 im)) #s(literal 3 binary64))) (fma.f64 (cosh.f64 im) (cosh.f64 im) (-.f64 (*.f64 (sinh.f64 (neg.f64 im)) (sinh.f64 (neg.f64 im))) (*.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im))))))
(/.f64 (-.f64 (pow.f64 (cosh.f64 im) #s(literal 3 binary64)) (pow.f64 (sinh.f64 im) #s(literal 3 binary64))) (fma.f64 (cosh.f64 im) (cosh.f64 im) (fma.f64 (sinh.f64 im) (sinh.f64 im) (*.f64 (cosh.f64 im) (sinh.f64 im)))))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 im)))
(/.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (exp.f64 (-.f64 im #s(literal 0 binary64)))))
(/.f64 #s(literal 2 binary64) (*.f64 #s(literal 2 binary64) (exp.f64 im)))
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 (exp.f64 im))))
(/.f64 #s(literal 1 binary64) (pow.f64 (exp.f64 im) #s(literal 1 binary64)))
(/.f64 #s(literal 1 binary64) (exp.f64 (-.f64 im #s(literal 0 binary64))))
(/.f64 #s(literal 1 binary64) (exp.f64 im))
(/.f64 #s(literal -2 binary64) (*.f64 #s(literal 2 binary64) (neg.f64 (exp.f64 im))))
(-.f64 (cosh.f64 im) (sinh.f64 im))
(exp.f64 (+.f64 #s(literal 0 binary64) (neg.f64 im)))
(exp.f64 (-.f64 #s(literal 0 binary64) im))
(exp.f64 (*.f64 (log.f64 (exp.f64 #s(literal -1 binary64))) im))
(exp.f64 (*.f64 (log.f64 (exp.f64 im)) #s(literal -1 binary64)))
(exp.f64 (neg.f64 im))
(+.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) re) #s(literal -1/2 binary64)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 #s(literal 1/12 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (sinh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal -1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/240 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (sinh.f64 im)) (*.f64 #s(literal 1/12 binary64) (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal -1/2 binary64))) re))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/10080 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (sinh.f64 im)) (*.f64 #s(literal -1/240 binary64) (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1/12 binary64) (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal -1/2 binary64))) re))
#s(approx (* 1/2 (sin re)) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 re #s(literal 1/2 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re))
#s(approx (+ (* (* re re) -1/12) 1/2) #s(literal 1/2 binary64))
#s(approx (+ (* (* re re) -1/12) 1/2) (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)))
#s(approx (* re re) (*.f64 re re))
#s(approx re re)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (fma.f64 (*.f64 (*.f64 re re) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) #s(literal -1/12 binary64) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) #s(literal 1/240 binary64) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) #s(literal -1/12 binary64))) (*.f64 re re) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) #s(literal 1/2 binary64))) re))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)))) #s(literal -1/10080 binary64) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) #s(literal 1/240 binary64))) (*.f64 re re) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) #s(literal -1/12 binary64))) (*.f64 re re) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) #s(literal 1/2 binary64))) re))
#s(approx (sin re) re)
#s(approx (sin re) (*.f64 (fma.f64 #s(literal -1/6 binary64) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 #s(literal 1/120 binary64) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (sin re) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/5040 binary64) (*.f64 re re) #s(literal 1/120 binary64)) (*.f64 re re) #s(literal -1/6 binary64)) (*.f64 re re) #s(literal 1 binary64)) re))
#s(approx (* (neg im) (sin re)) (*.f64 (neg.f64 im) re))
#s(approx (* (neg im) (sin re)) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im) re))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re))
#s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal 1/5040 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal -1/120 binary64) im)) (*.f64 #s(literal 1/6 binary64) im)) (*.f64 re re) (neg.f64 im)) re))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (neg.f64 im) re))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im) re))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (neg.f64 im))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (-.f64 (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)) im))
#s(approx (* (* re re) im) (*.f64 (*.f64 re re) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) (sin.f64 re)) #s(literal -1/2 binary64)))
#s(approx (* 1/2 (sin re)) (*.f64 (sin.f64 re) #s(literal 1/2 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/12 binary64)) (*.f64 (*.f64 re re) re)))
#s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64)))
#s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/12 binary64)) (*.f64 re re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (*.f64 (sin.f64 re) #s(literal 1/2 binary64))))
#s(approx (sin re) (sin.f64 re))
#s(approx (* (neg im) (sin re)) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (fma.f64 #s(literal 1/6 binary64) im (/.f64 (neg.f64 im) (*.f64 re re))) (*.f64 (*.f64 re re) re)))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64)))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 #s(literal 1/6 binary64) im (/.f64 (neg.f64 im) (*.f64 re re))) (*.f64 re re)))
#s(approx (* (+ (* (* re re) -1/12) 1/2) re) (neg.f64 (*.f64 (-.f64 #s(literal 1/12 binary64) (/.f64 #s(literal 1/2 binary64) (*.f64 re re))) (*.f64 (*.f64 re re) re))))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (neg.f64 (*.f64 (fma.f64 #s(literal -1/6 binary64) im (/.f64 im (*.f64 re re))) (*.f64 (*.f64 re re) re))))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (*.f64 #s(literal -1/6 binary64) (*.f64 im im)) (sin.f64 re) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/120 binary64) (*.f64 (sin.f64 re) #s(literal -1/6 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* -2 (sinh im)) (* 1/2 (sin re))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) (sin.f64 re) (*.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/5040 binary64) (*.f64 (sin.f64 re) #s(literal -1/120 binary64))) (*.f64 im im))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* -2 (sinh im)) (*.f64 im #s(literal -2 binary64)))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* -2 (sinh im)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 im #s(literal -2 binary64)))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im))
#s(approx (+ (* -1/3 (* im im)) -2) #s(literal -2 binary64))
#s(approx (+ (* -1/3 (* im im)) -2) (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)))
#s(approx (* im im) (*.f64 im im))
#s(approx im im)
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (fma.f64 (*.f64 #s(literal -1/6 binary64) (*.f64 im im)) (sin.f64 re) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/120 binary64) (*.f64 (sin.f64 re) #s(literal -1/6 binary64))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) (sin.f64 re) (*.f64 (fma.f64 (*.f64 (*.f64 im im) (sin.f64 re)) #s(literal -1/5040 binary64) (*.f64 (sin.f64 re) #s(literal -1/120 binary64))) (*.f64 im im))) (*.f64 im im) (neg.f64 (sin.f64 re))) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 im #s(literal -2 binary64)))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (fma.f64 #s(literal -1/60 binary64) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/2520 binary64) (*.f64 im im) #s(literal -1/60 binary64)) (*.f64 im im) #s(literal -1/3 binary64)) (*.f64 im im) #s(literal -2 binary64)) im))
#s(approx (exp (neg im)) #s(literal 1 binary64))
#s(approx (exp (neg im)) (+.f64 (neg.f64 im) #s(literal 1 binary64)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp (neg im)) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal -1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp im) #s(literal 1 binary64))
#s(approx (exp im) (+.f64 #s(literal 1 binary64) im))
#s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (exp im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) im #s(literal 1/2 binary64)) im #s(literal 1 binary64)) im #s(literal 1 binary64)))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im))
#s(approx (neg im) (neg.f64 im))
#s(approx (sinh im) im)
#s(approx (sinh im) (*.f64 (fma.f64 (*.f64 im im) #s(literal 1/6 binary64) #s(literal 1 binary64)) im))
#s(approx (sinh im) (*.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/120 binary64) #s(literal 1/6 binary64)) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx (sinh im) (*.f64 (fma.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/5040 binary64) #s(literal 1/120 binary64)) (*.f64 im im) #s(literal 1/6 binary64)) (*.f64 im im) #s(literal 1 binary64)) im))
#s(approx (* -2 (sinh im)) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))
#s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) (neg.f64 im)) (+.f64 (/.f64 #s(literal 2 binary64) (*.f64 im im)) #s(literal 1/3 binary64))))
#s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64)))
#s(approx (+ (* -1/3 (* im im)) -2) (neg.f64 (*.f64 (+.f64 (/.f64 #s(literal 2 binary64) (*.f64 im im)) #s(literal 1/3 binary64)) (*.f64 im im))))
#s(approx (- (exp (neg im)) (exp im)) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (exp im) (exp.f64 im))
#s(approx (sinh im) (*.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im)) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) (*.f64 (sin.f64 re) #s(literal 1/2 binary64))))
#s(approx (- (exp (neg im)) (exp im)) (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))))
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im)))
#s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (neg.f64 im) (*.f64 (fma.f64 #s(literal -1/6 binary64) (*.f64 re re) #s(literal 1 binary64)) re)))
#s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (neg.f64 im) (fma.f64 #s(literal -1/6 binary64) (*.f64 re re) #s(literal 1 binary64))))

eval56.0ms (0.8%)

Memory
-11.8MiB live, 91.7MiB allocated; 32ms collecting garbage
Compiler

Compiled 4 219 to 1 511 computations (64.2% saved)

prune29.0ms (0.4%)

Memory
16.6MiB live, 62.8MiB allocated; 4ms collecting garbage
Pruning

30 alts after pruning (25 fresh and 5 done)

PrunedKeptTotal
New34213355
Fresh21214
Picked325
Done033
Total34730377
Accuracy
99.9%
Counts
377 → 30
Alt Table
Click to see full alt table
StatusAccuracyProgram
16.3%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
24.2%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
40.6%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
15.7%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
56.5%
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
26.6%
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
36.6%
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
35.7%
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
23.7%
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
23.7%
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
54.1%
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
47.4%
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
47.4%
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
54.5%
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
64.7%
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
25.3%
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
50.0%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
51.0%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
32.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
52.5%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
42.6%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
40.9%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
46.6%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
34.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
34.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
23.6%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
34.8%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
23.7%
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
Compiler

Compiled 1 137 to 929 computations (18.3% saved)

regimes79.0ms (1.2%)

Memory
0.9MiB live, 144.3MiB allocated; 18ms collecting garbage
Counts
46 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Calls

6 calls:

15.0ms
(sin.f64 re)
15.0ms
im
13.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
12.0ms
re
12.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Results
AccuracySegmentsBranch
99.9%2(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
79.8%3(sin.f64 re)
79.8%3(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
99.9%3(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
83.9%4re
99.9%2im
Compiler

Compiled 23 to 28 computations (-21.7% saved)

regimes82.0ms (1.2%)

Memory
-28.5MiB live, 63.4MiB allocated; 8ms collecting garbage
Counts
44 → 3
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Outputs
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (neg.f64 im) (sin.f64 re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
Calls

3 calls:

57.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
15.0ms
im
8.0ms
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
Results
AccuracySegmentsBranch
99.9%3(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
87.8%2(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
90.2%3im
Compiler

Compiled 16 to 18 computations (-12.5% saved)

regimes67.0ms (1%)

Memory
38.1MiB live, 133.5MiB allocated; 10ms collecting garbage
Counts
42 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/10080 binary64) (*.f64 re re) #s(literal 1/240 binary64)) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (sinh.f64 (*.f64 #s(literal -2 binary64) im)) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (sinh.f64 (*.f64 im #s(literal -2 binary64))) (/.f64 re (cosh.f64 im))) #s(literal 1/2 binary64)))
Outputs
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
Calls

6 calls:

14.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
11.0ms
re
11.0ms
(sin.f64 re)
11.0ms
im
10.0ms
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
Results
AccuracySegmentsBranch
77.3%2(sin.f64 re)
77.3%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
67.4%2re
64.8%1(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
69.0%3im
77.2%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Compiler

Compiled 23 to 28 computations (-21.7% saved)

regimes58.0ms (0.9%)

Memory
15.0MiB live, 51.8MiB allocated; 11ms collecting garbage
Counts
36 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
Outputs
(*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
Calls

2 calls:

46.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
10.0ms
(sin.f64 re)
Results
AccuracySegmentsBranch
77.3%2(sin.f64 re)
77.3%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 6 to 8 computations (-33.3% saved)

regimes80.0ms (1.2%)

Memory
-29.4MiB live, 106.0MiB allocated; 51ms collecting garbage
Counts
34 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
Outputs
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
Calls

3 calls:

17.0ms
(sin.f64 re)
13.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
9.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Results
AccuracySegmentsBranch
77.2%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
77.1%2(sin.f64 re)
77.1%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 16 to 18 computations (-12.5% saved)

regimes66.0ms (1%)

Memory
47.6MiB live, 130.7MiB allocated; 28ms collecting garbage
Counts
33 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (fma.f64 #s(literal 1/240 binary64) (*.f64 re re) #s(literal -1/12 binary64)) (*.f64 re re) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 re re) (fma.f64 #s(literal -1/120 binary64) (*.f64 (*.f64 re re) im) (*.f64 #s(literal 1/6 binary64) im)) (neg.f64 im)) re)))
Outputs
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
Calls

3 calls:

28.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
23.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
12.0ms
(sin.f64 re)
Results
AccuracySegmentsBranch
76.2%2(sin.f64 re)
76.2%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
76.1%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Compiler

Compiled 16 to 18 computations (-12.5% saved)

regimes59.0ms (0.9%)

Memory
-24.8MiB live, 38.2MiB allocated; 55ms collecting garbage
Counts
30 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 #s(approx (* -2 (sinh im)) (*.f64 #s(approx (+ (* -1/3 (* im im)) -2) (*.f64 (*.f64 im im) #s(literal -1/3 binary64))) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
Outputs
(*.f64 #s(approx (* -2 (sinh im)) #s(approx (* (+ (* -1/3 (* im im)) -2) im) (*.f64 (*.f64 (*.f64 im im) im) #s(literal -1/3 binary64)))) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
Calls

2 calls:

49.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
8.0ms
(sin.f64 re)
Results
AccuracySegmentsBranch
76.2%2(sin.f64 re)
76.2%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 6 to 8 computations (-33.3% saved)

regimes73.0ms (1.1%)

Memory
-8.0MiB live, 40.6MiB allocated; 10ms collecting garbage
Counts
28 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (fma.f64 #s(literal -1/6 binary64) re (/.f64 (neg.f64 re) (*.f64 im im))) (*.f64 (*.f64 im im) im)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 (neg.f64 (*.f64 #s(literal 2 binary64) (sinh.f64 im))) re) #s(literal 1/2 binary64)))
Outputs
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 (*.f64 #s(literal -2 binary64) (sinh.f64 im)) re) #s(literal 1/2 binary64)))
Calls

3 calls:

58.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
8.0ms
(sin.f64 re)
6.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Results
AccuracySegmentsBranch
73.9%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
74.3%2(sin.f64 re)
74.3%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 16 to 18 computations (-12.5% saved)

regimes22.0ms (0.3%)

Memory
-9.4MiB live, 36.5MiB allocated; 3ms collecting garbage
Counts
25 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 (exp.f64 (neg.f64 im)) #s(approx (exp im) #s(literal 1 binary64))))
Outputs
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(approx (sin re) re) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
Calls

3 calls:

7.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
7.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
7.0ms
(sin.f64 re)
Results
AccuracySegmentsBranch
73.4%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
68.3%3(sin.f64 re)
68.3%3(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 16 to 18 computations (-12.5% saved)

regimes62.0ms (0.9%)

Memory
20.8MiB live, 66.5MiB allocated; 5ms collecting garbage
Counts
22 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
Outputs
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal -1 binary64)) im #s(literal 1 binary64))) #s(approx (exp im) #s(literal 1 binary64))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
Calls

6 calls:

33.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
6.0ms
(sin.f64 re)
6.0ms
re
6.0ms
im
4.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Results
AccuracySegmentsBranch
56.5%1(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
66.1%2(sin.f64 re)
66.1%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
56.5%1re
56.5%1im
65.8%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Compiler

Compiled 23 to 28 computations (-21.7% saved)

regimes19.0ms (0.3%)

Memory
-21.2MiB live, 30.1MiB allocated; 11ms collecting garbage
Counts
21 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) (*.f64 (*.f64 #s(approx (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im))) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
#s(approx (* (* 1/2 (sin re)) (/ (- (exp (* (neg im) 2)) (exp (+ im im))) (+ (exp (neg im)) (exp im)))) (*.f64 (*.f64 #s(approx (* -2 (sinh im)) (*.f64 (fma.f64 #s(literal -1/3 binary64) (*.f64 im im) #s(literal -2 binary64)) im)) re) #s(literal 1/2 binary64)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/12 binary64) #s(literal 1/2 binary64)) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (fma.f64 (neg.f64 re) im (*.f64 (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64)) im))))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) (fma.f64 (fma.f64 #s(literal 1/2 binary64) im #s(literal 1 binary64)) im #s(literal 1 binary64)))))
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) #s(approx (- (exp (neg im)) (exp im)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/3 binary64) #s(literal -2 binary64)) im)))
Calls

2 calls:

11.0ms
(sin.f64 re)
6.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Results
AccuracySegmentsBranch
65.8%2(sin.f64 re)
65.8%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 6 to 8 computations (-33.3% saved)

regimes12.0ms (0.2%)

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

2 calls:

5.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
5.0ms
(sin.f64 re)
Results
AccuracySegmentsBranch
65.8%2(sin.f64 re)
65.8%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 6 to 8 computations (-33.3% saved)

regimes15.0ms (0.2%)

Memory
-15.5MiB live, 30.4MiB allocated; 3ms collecting garbage
Counts
15 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64))) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) re) im))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 #s(approx (+ (* (* (* im im) re) -1/6) (neg re)) (*.f64 (fma.f64 (*.f64 im im) #s(literal -1/6 binary64) #s(literal -1 binary64)) re)) im)))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) #s(approx (* (+ (* (* re re) -1/12) 1/2) re) (*.f64 (*.f64 (*.f64 re re) re) #s(literal -1/12 binary64)))))
(*.f64 (*.f64 #s(literal -2 binary64) #s(approx (sinh im) im)) #s(approx (* 1/2 (sin re)) (*.f64 #s(approx (+ (* (* re re) -1/12) 1/2) (*.f64 (*.f64 re re) #s(literal -1/12 binary64))) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 (fma.f64 (*.f64 (*.f64 re re) im) #s(literal 1/6 binary64) (neg.f64 im)) re)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im im) (*.f64 #s(literal -1/6 binary64) re) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 im (*.f64 re im)) #s(literal -1/6 binary64) (neg.f64 re)) im)))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (fma.f64 (*.f64 (*.f64 im im) re) #s(literal -1/6 binary64) (neg.f64 re)) im)))
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) #s(approx (* (+ (* (* (* im im) re) -1/6) (neg re)) im) (*.f64 (*.f64 (*.f64 (*.f64 im im) im) re) #s(literal -1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) (*.f64 #s(approx (+ (* (* (* re re) im) 1/6) (neg im)) (*.f64 (fma.f64 (*.f64 re re) #s(literal 1/6 binary64) #s(literal -1 binary64)) im)) re)))
Calls

3 calls:

6.0ms
(sin.f64 re)
4.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
3.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Results
AccuracySegmentsBranch
65.4%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
61.8%2(sin.f64 re)
61.8%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 16 to 18 computations (-12.5% saved)

regimes3.0ms (0%)

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

1 calls:

2.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Results
AccuracySegmentsBranch
65.4%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Compiler

Compiled 10 to 10 computations (0% saved)

regimes2.0ms (0%)

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

1 calls:

2.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Results
AccuracySegmentsBranch
65.7%3(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Compiler

Compiled 10 to 10 computations (0% saved)

regimes10.0ms (0.2%)

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

6 calls:

2.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
2.0ms
(sin.f64 re)
2.0ms
re
2.0ms
im
1.0ms
(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Results
AccuracySegmentsBranch
34.5%2(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
37.3%3im
35.2%2re
42.1%2(sin.f64 re)
42.1%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
42.0%2(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
Compiler

Compiled 23 to 28 computations (-21.7% saved)

regimes12.0ms (0.2%)

Memory
-39.1MiB live, 6.8MiB allocated; 2ms collecting garbage
Counts
3 → 2
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (neg im) (sin re)) #s(approx (* (+ (* (* (* re re) im) 1/6) (neg im)) re) (*.f64 (*.f64 (*.f64 (*.f64 re re) re) im) #s(literal 1/6 binary64)))))
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
Calls

2 calls:

10.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
2.0ms
(sin.f64 re)
Results
AccuracySegmentsBranch
42.1%2(sin.f64 re)
42.1%2(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 6 to 8 computations (-33.3% saved)

regimes8.0ms (0.1%)

Memory
16.1MiB live, 16.1MiB allocated; 0ms collecting garbage
Accuracy

Total -11.4b remaining (-26.5%)

Threshold costs -11.4b (-26.5%)

Counts
2 → 1
Calls
Call 1
Inputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (sin re) re)) (-.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) #s(approx (exp im) #s(literal 1 binary64))))
Outputs
#s(approx (* (* 1/2 (sin re)) (- (exp (neg im)) (exp im))) #s(approx (* (* (neg (* 2 (sinh im))) re) 1/2) (*.f64 (neg.f64 im) re)))
Calls

6 calls:

1.0ms
(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
1.0ms
(sin.f64 re)
1.0ms
im
1.0ms
re
1.0ms
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
Results
AccuracySegmentsBranch
32.8%1(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))
32.8%1re
32.8%1im
32.8%1(*.f64 (*.f64 #s(literal 1/2 binary64) (sin.f64 re)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))
32.8%1(sin.f64 re)
32.8%1(*.f64 #s(literal 1/2 binary64) (sin.f64 re))
Compiler

Compiled 23 to 28 computations (-21.7% saved)

bsearch34.0ms (0.5%)

Memory
-11.5MiB live, 34.5MiB allocated; 3ms collecting garbage
Algorithm
binary-search
Stop Event
narrow-enough
Steps
TimeLeftRight
32.0ms
1.7509551378539128e-10
12.517379387595948
Samples
20.0ms124×0valid
6.0ms36×1valid
Compiler

Compiled 254 to 275 computations (-8.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 22.0ms
ival-neg: 11.0ms (49.1% of total)
ival-sin: 5.0ms (22.3% of total)
ival-exp: 4.0ms (17.8% of total)
ival-mult!: 2.0ms (8.9% of total)
adjust: 1.0ms (4.5% of total)
ival-sub!: 0.0ms (0% of total)

bsearch1.0ms (0%)

Memory
1.2MiB live, 1.2MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.0
+inf
0.0ms
-1.920459457261622e-49
-5.544628870378195e-61
Compiler

Compiled 13 to 15 computations (-15.4% saved)

bsearch0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
2.506662930235198e-186
6.679932551568714e-181
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

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

Compiled 13 to 15 computations (-15.4% saved)

bsearch0.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.00420185753177251
3.746531309935395e-304
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.920459457261622e-49
-5.544628870378195e-61
Compiler

Compiled 13 to 15 computations (-15.4% saved)

bsearch0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.00420185753177251
3.746531309935395e-304
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.7MiB live, 0.7MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.920459457261622e-49
-5.544628870378195e-61
Compiler

Compiled 13 to 15 computations (-15.4% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-1.920459457261622e-49
-5.544628870378195e-61
Compiler

Compiled 13 to 15 computations (-15.4% saved)

bsearch0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
0.0
+inf
0.0ms
-1.920459457261622e-49
-5.544628870378195e-61
Compiler

Compiled 13 to 15 computations (-15.4% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

bsearch0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
-0.03190612420774632
-0.00420185753177251
Compiler

Compiled 14 to 15 computations (-7.1% saved)

derivations1.5s (22.7%)

Memory
-116.9MiB live, 653.9MiB allocated; 1.5s collecting garbage
Stop Event
fuel
Compiler

Compiled 294 to 172 computations (41.5% saved)

preprocess631.0ms (9.4%)

Memory
5.0MiB live, 911.6MiB allocated; 194ms collecting garbage
Remove

(negabs im)

(negabs re)

Compiler

Compiled 4 692 to 3 938 computations (16.1% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...