
Time bar (total: 6.1s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 100% | 99.9% | 0% | 0.1% | 0% | 0% | 0% | 1 |
Compiled 13 to 12 computations (7.7% saved)
| 1.2s | 8 256× | 0 | valid |
ival-cos: 506.0ms (58% of total)ival-exp: 190.0ms (21.8% of total)ival-mult!: 101.0ms (11.6% of total)ival-neg: 48.0ms (5.5% of total)ival-add!: 25.0ms (2.9% of total)adjust: 2.0ms (0.2% of total)Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 26 | 68 |
| 1 | 112 | 54 |
| 2 | 363 | 44 |
| 3 | 1989 | 34 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(abs re)
(abs im)
Compiled 20 to 20 computations (0% saved)
| Inputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.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 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (+ (exp im) (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/2 (+ (exp im) (exp (neg im))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* 1/48 (* (pow re 2) (+ (exp im) (exp (neg im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/48 (+ (exp im) (exp (neg im))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (neg im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#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 (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 im) (exp (neg 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 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (* -1 im))))))) |
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (* -1 im))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | im | @ | inf | ((* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im)) |
| 2.0ms | im | @ | 0 | ((* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im)) |
| 2.0ms | im | @ | -inf | ((* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im)) |
| 2.0ms | re | @ | inf | ((* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im)) |
| 1.0ms | re | @ | -inf | ((* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) im (exp im)) |
| Inputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.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 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (+ (exp im) (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/2 (+ (exp im) (exp (neg im))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* 1/48 (* (pow re 2) (+ (exp im) (exp (neg im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/48 (+ (exp im) (exp (neg im))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (neg im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#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 (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 im) (exp (neg 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 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (* -1 im))))))) |
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (* -1 im))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(+.f64 (*.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(fma.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
(*.f64 (cos.f64 re) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
(neg.f64 #s(literal -1/2 binary64)) |
(cos.f64 re) |
(cos.f64 (neg.f64 re)) |
(sin.f64 (+.f64 re (/.f64 (PI.f64) #s(literal 2 binary64)))) |
re |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
(+.f64 (exp.f64 im) (exp.f64 (neg.f64 im))) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(/.f64 (-.f64 (*.f64 (exp.f64 im) (exp.f64 im)) (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im)))) (-.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))) |
(/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 im) #s(literal 3 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64))) (fma.f64 (exp.f64 im) (exp.f64 im) (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64)) (pow.f64 (exp.f64 im) #s(literal 3 binary64))) (fma.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im)) (-.f64 (*.f64 (exp.f64 im) (exp.f64 im)) (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))))) |
(+.f64 (cosh.f64 (neg.f64 im)) (sinh.f64 (neg.f64 im))) |
(-.f64 (cosh.f64 im) (sinh.f64 im)) |
(/.f64 #s(literal 1 binary64) (exp.f64 im)) |
(exp.f64 (neg.f64 im)) |
(pow.f64 (exp.f64 #s(literal -1 binary64)) im) |
(*.f64 #s(literal -1 binary64) im) |
(*.f64 im #s(literal -1 binary64)) |
(neg.f64 im) |
im |
(+.f64 (cosh.f64 im) (sinh.f64 im)) |
(exp.f64 im) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/4 binary64)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal 1/48 binary64)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal -1/4 binary64))) (*.f64 re re) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 re re) #s(literal -1/1440 binary64)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/48 binary64))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal -1/4 binary64))) (*.f64 re re) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 (*.f64 re re) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/1440 binary64) #s(literal 1/48 binary64)) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (cos re) #s(literal 1 binary64)) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 (*.f64 re re) #s(literal 1/24 binary64)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 (*.f64 re re) #s(literal -1/720 binary64) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx re re) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 1/2 (cos re)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
#s(approx (cos re) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* 2 (cosh 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 (* 2 (cosh im)) (fma.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/360 binary64) #s(literal 1/12 binary64)) (*.f64 im im) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64))) |
#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 (-.f64 (*.f64 #s(literal 1/2 binary64) im) #s(literal 1 binary64)) im #s(literal 1 binary64))) |
#s(approx (exp (neg im)) (fma.f64 (-.f64 (*.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 #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 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
#s(approx (exp im) (exp.f64 im)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
Compiled 527 to 265 computations (49.7% saved)
8 alts after pruning (8 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 54 | 8 | 62 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 55 | 8 | 63 |
| Status | Accuracy | Program |
|---|---|---|
| 100.0% | (fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) | |
| ▶ | 2.7% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) |
| ▶ | 98.9% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
| ▶ | 100.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
| 74.7% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) | |
| ▶ | 65.0% | (*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| ▶ | 71.7% | #s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
| 48.2% | #s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
Compiled 212 to 196 computations (7.5% saved)
| Inputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.f64 re) |
re |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
#s(literal 2 binary64) |
(cosh.f64 im) |
im |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(*.f64 re re) |
#s(literal -1/4 binary64) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(exp.f64 (neg.f64 im)) |
(neg.f64 im) |
(exp.f64 im) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.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)) |
#s(approx (exp (neg im)) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) |
(/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) |
(*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) |
(*.f64 (exp.f64 im) (exp.f64 im)) |
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| Outputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (+ (exp im) (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/2 (+ (exp im) (exp (neg im))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* 1/48 (* (pow re 2) (+ (exp im) (exp (neg im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/48 (+ (exp im) (exp (neg im))))))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (* -1/4 (/ (* (pow re 2) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im)))) (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* (pow re 2) (+ (* -1/4 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* 1/48 (/ (* (pow re 2) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im))))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* (pow re 2) (+ (* -1/4 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* (pow re 2) (+ (* -1/1440 (/ (* (pow re 2) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im)))) (* 1/48 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im))))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (neg im))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* -1/4 (pow re 2)))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/4)))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (cos re) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 2)) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2))))))))) |
#s(approx (cosh im) #s(hole binary64 1)) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx im #s(hole binary64 im)) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 1)) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#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 (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 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* 4/15 (cos re)) (+ (* 1/60 (cos re)) (* 1/6 (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))) (* 1/2 (- (* 4/3 (cos re)) (* 1/3 (cos re))))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (- (* 4/3 (cos re)) (* 1/3 (cos re)))) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* 8/315 (cos re)) (+ (* 1/2520 (cos re)) (+ (* 1/120 (- (* 4/3 (cos re)) (* 1/3 (cos re)))) (* 1/6 (- (* 4/15 (cos re)) (+ (* 1/60 (cos re)) (* 1/6 (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))))))) (* 1/2 (- (* 4/15 (cos re)) (+ (* 1/60 (cos re)) (* 1/6 (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))))))))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 2)) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (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 (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (* -4 im))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (* im (- (* -8/3 (pow im 2)) 4)))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -8/15 (pow im 2)) 8/3)) 4)))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp 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)) (exp (neg im))) #s(hole binary64 1)) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (+ 1 (* -2 im)))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (+ 1 (* im (- (* 2 im) 2))))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (+ 1 (* im (- (* im (+ 2 (* -4/3 im))) 2))))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 1)) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (+ 1 (* 2 im)))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (+ 1 (* im (+ 2 (* 2 im)))))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (+ 1 (* im (+ 2 (* im (+ 2 (* 4/3 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 (* 2 (cosh im)) #s(hole binary64 (+ (exp im) (/ 1 (exp im))))) |
#s(approx (cosh im) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (neg 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)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im))))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (- (pow (exp (neg im)) 2) (pow (exp im) 2)))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (pow (exp (neg im)) 2))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (pow (exp im) 2))) |
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im)))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (* -1 im))))))) |
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (* -1 im))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (cos re) (- (pow (exp (* -1 im)) 2) (pow (exp im) 2))) (- (exp (* -1 im)) (exp im)))))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (pow (exp (* -1 im)) 2) (pow (exp im) 2)) (- (exp (* -1 im)) (exp im))))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (- (pow (exp (* -1 im)) 2) (pow (exp im) 2)))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (pow (exp (* -1 im)) 2))) |
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 19.0ms | re | @ | -inf | ((* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) 1/2 (cos re) re (* 2 (cosh im)) 2 (cosh im) im (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (* 2 (cosh im))) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (+ (exp (neg im)) (exp im)) (exp (neg im)) 1 (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im)) (- (exp (neg im)) (exp im))) |
| 9.0ms | im | @ | inf | ((* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) 1/2 (cos re) re (* 2 (cosh im)) 2 (cosh im) im (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (* 2 (cosh im))) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (+ (exp (neg im)) (exp im)) (exp (neg im)) 1 (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im)) (- (exp (neg im)) (exp im))) |
| 6.0ms | re | @ | 0 | ((* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) 1/2 (cos re) re (* 2 (cosh im)) 2 (cosh im) im (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (* 2 (cosh im))) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (+ (exp (neg im)) (exp im)) (exp (neg im)) 1 (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im)) (- (exp (neg im)) (exp im))) |
| 6.0ms | im | @ | -inf | ((* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) 1/2 (cos re) re (* 2 (cosh im)) 2 (cosh im) im (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (* 2 (cosh im))) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (+ (exp (neg im)) (exp im)) (exp (neg im)) 1 (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im)) (- (exp (neg im)) (exp im))) |
| 4.0ms | im | @ | 0 | ((* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) 1/2 (cos re) re (* 2 (cosh im)) 2 (cosh im) im (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (* 2 (cosh im))) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (+ (exp (neg im)) (exp im)) (exp (neg im)) (neg im) (exp im) (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) (+ (exp (neg im)) (exp im)) (exp (neg im)) 1 (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im)) (- (exp (neg im)) (exp im))) |
| Inputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.f64 re) |
re |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
#s(literal 2 binary64) |
(cosh.f64 im) |
im |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(*.f64 re re) |
#s(literal -1/4 binary64) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(exp.f64 (neg.f64 im)) |
(neg.f64 im) |
(exp.f64 im) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.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)) |
#s(approx (exp (neg im)) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) |
(/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) |
(*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) |
(*.f64 (exp.f64 im) (exp.f64 im)) |
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (+ (exp im) (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/2 (+ (exp im) (exp (neg im))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* 1/48 (* (pow re 2) (+ (exp im) (exp (neg im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (exp (neg im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (exp (neg im))))) (* 1/48 (+ (exp im) (exp (neg im))))))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (* -1/4 (/ (* (pow re 2) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im)))) (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* (pow re 2) (+ (* -1/4 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* 1/48 (/ (* (pow re 2) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im))))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (* 1/2 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* (pow re 2) (+ (* -1/4 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im)))) (* (pow re 2) (+ (* -1/1440 (/ (* (pow re 2) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im)))) (* 1/48 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im))))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (neg im))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* -1/4 (pow re 2)))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/4)))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (cos re) (- (pow (exp (neg im)) 2) (pow (exp im) 2))) (- (exp (neg im)) (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 2)) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2))))))))) |
#s(approx (cosh im) #s(hole binary64 1)) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx im #s(hole binary64 im)) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 1)) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#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 (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 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* 4/15 (cos re)) (+ (* 1/60 (cos re)) (* 1/6 (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))) (* 1/2 (- (* 4/3 (cos re)) (* 1/3 (cos re))))))))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (- (* 4/3 (cos re)) (* 1/3 (cos re)))) (* (pow im 2) (+ (* 1/2 (* (pow im 2) (- (* 8/315 (cos re)) (+ (* 1/2520 (cos re)) (+ (* 1/120 (- (* 4/3 (cos re)) (* 1/3 (cos re)))) (* 1/6 (- (* 4/15 (cos re)) (+ (* 1/60 (cos re)) (* 1/6 (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))))))) (* 1/2 (- (* 4/15 (cos re)) (+ (* 1/60 (cos re)) (* 1/6 (- (* 4/3 (cos re)) (* 1/3 (cos re)))))))))))))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 2)) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (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 (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (* -4 im))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (* im (- (* -8/3 (pow im 2)) 4)))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (* im (- (* (pow im 2) (- (* -8/15 (pow im 2)) 8/3)) 4)))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp 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)) (exp (neg im))) #s(hole binary64 1)) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (+ 1 (* -2 im)))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (+ 1 (* im (- (* 2 im) 2))))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (+ 1 (* im (- (* im (+ 2 (* -4/3 im))) 2))))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 1)) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (+ 1 (* 2 im)))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (+ 1 (* im (+ 2 (* 2 im)))))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (+ 1 (* im (+ 2 (* im (+ 2 (* 4/3 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 (* 2 (cosh im)) #s(hole binary64 (+ (exp im) (/ 1 (exp im))))) |
#s(approx (cosh im) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* 1/2 (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (neg 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)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (pow (exp (neg im)) 2) (pow (exp im) 2)) (- (exp (neg im)) (exp im))))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (- (pow (exp (neg im)) 2) (pow (exp im) 2)))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (pow (exp (neg im)) 2))) |
#s(approx (* (exp im) (exp im)) #s(hole binary64 (pow (exp im) 2))) |
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (neg im)) (exp im)))) |
#s(approx (* (* 1/2 (cos re)) (+ (exp (neg im)) (exp im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (exp (* -1 im))))))) |
#s(approx (+ (exp (neg im)) (exp im)) #s(hole binary64 (+ (exp im) (exp (* -1 im))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
#s(approx (* (* 1/2 (cos re)) (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im)))) #s(hole binary64 (* 1/2 (/ (* (cos re) (- (pow (exp (* -1 im)) 2) (pow (exp im) 2))) (- (exp (* -1 im)) (exp im)))))) |
#s(approx (/ (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) (- (exp (neg im)) (exp im))) #s(hole binary64 (/ (- (pow (exp (* -1 im)) 2) (pow (exp im) 2)) (- (exp (* -1 im)) (exp im))))) |
#s(approx (- (* (exp (neg im)) (exp (neg im))) (* (exp im) (exp im))) #s(hole binary64 (- (pow (exp (* -1 im)) 2) (pow (exp im) 2)))) |
#s(approx (* (exp (neg im)) (exp (neg im))) #s(hole binary64 (pow (exp (* -1 im)) 2))) |
#s(approx (- (exp (neg im)) (exp im)) #s(hole binary64 (- (exp (* -1 im)) (exp im)))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(literal 2 binary64)) (cosh.f64 im)) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(+.f64 (*.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (-.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 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (-.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))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(fma.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
(*.f64 (cos.f64 re) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
(*.f64 #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(neg.f64 #s(literal -1/2 binary64)) |
(cos.f64 re) |
(cos.f64 (neg.f64 re)) |
(sin.f64 (+.f64 re (/.f64 (PI.f64) #s(literal 2 binary64)))) |
re |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
(*.f64 (cosh.f64 im) #s(literal 2 binary64)) |
(+.f64 (exp.f64 im) (exp.f64 (neg.f64 im))) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(+.f64 (cosh.f64 im) (cosh.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 2 binary64))) (exp.f64 (+.f64 im im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(/.f64 (-.f64 (exp.f64 (+.f64 im im)) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))) (-.f64 (exp.f64 im) (exp.f64 (neg.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 (+.f64 (pow.f64 (exp.f64 im) #s(literal 3 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (*.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64)) (pow.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)) (exp.f64 im))))) |
#s(literal 2 binary64) |
(+.f64 #s(literal 1 binary64) #s(literal 1 binary64)) |
(neg.f64 #s(literal -2 binary64)) |
(/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 2 binary64)) |
(cosh.f64 im) |
(cosh.f64 (neg.f64 im)) |
im |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(literal 1 binary64) (cosh.f64 im)) |
(*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 (exp.f64 im) #s(literal 1/2 binary64)) (*.f64 (exp.f64 (neg.f64 im)) #s(literal 1/2 binary64))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) (exp.f64 im)) (*.f64 #s(literal 1/2 binary64) (exp.f64 (neg.f64 im)))) |
(/.f64 (*.f64 #s(literal 1/2 binary64) (-.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))) |
(fma.f64 #s(literal 1/2 binary64) (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (exp.f64 (neg.f64 im)))) |
(fma.f64 (exp.f64 im) #s(literal 1/2 binary64) (*.f64 (exp.f64 (neg.f64 im)) #s(literal 1/2 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) |
(+.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) |
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) (*.f64 re re))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) #s(literal 1/4 binary64)) (-.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64))) |
(/.f64 (+.f64 (pow.f64 #s(literal 1/2 binary64) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 3 binary64)) (pow.f64 #s(literal 1/2 binary64) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64))))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64)) |
(fma.f64 re (*.f64 re #s(literal -1/4 binary64)) #s(literal 1/2 binary64)) |
(*.f64 re re) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 (pow.f64 re (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 re (/.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) |
(pow.f64 re #s(literal 2 binary64)) |
#s(literal -1/4 binary64) |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
(*.f64 (cosh.f64 im) #s(literal 2 binary64)) |
(+.f64 (exp.f64 im) (exp.f64 (neg.f64 im))) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(+.f64 (cosh.f64 im) (cosh.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 2 binary64))) (exp.f64 (+.f64 im im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(/.f64 (-.f64 (exp.f64 (+.f64 im im)) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))) (-.f64 (exp.f64 im) (exp.f64 (neg.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 (+.f64 (pow.f64 (exp.f64 im) #s(literal 3 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (*.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64)) (pow.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)) (exp.f64 im))))) |
(+.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im))) |
(-.f64 (cosh.f64 im) (sinh.f64 im)) |
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 im))) |
(/.f64 #s(literal 1 binary64) (exp.f64 im)) |
(exp.f64 (neg.f64 im)) |
(pow.f64 (exp.f64 #s(literal -1 binary64)) im) |
(pow.f64 (exp.f64 im) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) im) |
(*.f64 im #s(literal -1 binary64)) |
(neg.f64 im) |
(+.f64 (cosh.f64 im) (sinh.f64 im)) |
(exp.f64 im) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.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)) |
#s(approx (exp (neg im)) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64)) |
(*.f64 #s(literal 1/2 binary64) #s(literal 2 binary64)) |
(-.f64 #s(literal 4/3 binary64) #s(literal 1/3 binary64)) |
(cosh.f64 #s(literal 0 binary64)) |
(exp.f64 #s(literal 0 binary64)) |
(neg.f64 #s(literal -1 binary64)) |
(pow.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(literal 2 binary64)) (cosh.f64 im)) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(+.f64 (*.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (-.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 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (-.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))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(fma.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
(*.f64 (cosh.f64 im) #s(literal 2 binary64)) |
(+.f64 (exp.f64 im) (exp.f64 (neg.f64 im))) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(+.f64 (cosh.f64 im) (cosh.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 2 binary64))) (exp.f64 (+.f64 im im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(/.f64 (-.f64 (exp.f64 (+.f64 im im)) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))) (-.f64 (exp.f64 im) (exp.f64 (neg.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 (+.f64 (pow.f64 (exp.f64 im) #s(literal 3 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 im im)) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (*.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64)) (pow.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)) (exp.f64 im))))) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 im))) |
(-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) |
(/.f64 (-.f64 (*.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))) (*.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 im im)))) (+.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))) |
(/.f64 (-.f64 (pow.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) #s(literal 3 binary64)) (pow.f64 (exp.f64 (+.f64 im im)) #s(literal 3 binary64))) (fma.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (fma.f64 (exp.f64 (+.f64 im im)) (exp.f64 (+.f64 im im)) (*.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))))) |
(fma.f64 (pow.f64 (exp.f64 (neg.f64 im)) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 (exp.f64 (neg.f64 im)) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 im))) |
(fma.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im)) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 im))) |
(fma.f64 (neg.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 (neg.f64 im))) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 im))) |
(fma.f64 (fabs.f64 (exp.f64 (neg.f64 im))) (fabs.f64 (exp.f64 (neg.f64 im))) (*.f64 (neg.f64 (exp.f64 im)) (exp.f64 im))) |
(*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) |
(*.f64 (fabs.f64 (exp.f64 (neg.f64 im))) (fabs.f64 (exp.f64 (neg.f64 im)))) |
(*.f64 (neg.f64 (exp.f64 (neg.f64 im))) (neg.f64 (exp.f64 (neg.f64 im)))) |
(*.f64 (pow.f64 (exp.f64 (neg.f64 im)) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 (exp.f64 (neg.f64 im)) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) |
(exp.f64 (+.f64 (neg.f64 im) (neg.f64 im))) |
(exp.f64 (*.f64 (log.f64 (exp.f64 (neg.f64 im))) #s(literal 2 binary64))) |
(pow.f64 (exp.f64 (neg.f64 im)) #s(literal 2 binary64)) |
(*.f64 (exp.f64 im) (exp.f64 im)) |
(*.f64 (fabs.f64 (exp.f64 im)) (fabs.f64 (exp.f64 im))) |
(*.f64 (neg.f64 (exp.f64 im)) (neg.f64 (exp.f64 im))) |
(*.f64 (pow.f64 (exp.f64 im) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 (exp.f64 im) (/.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (log.f64 (exp.f64 im)) #s(literal 2 binary64))) |
(exp.f64 (+.f64 im im)) |
(pow.f64 (exp.f64 im) #s(literal 2 binary64)) |
(-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(/.f64 (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(/.f64 (-.f64 (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64)) (pow.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)) (exp.f64 im))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/1440 binary64) (*.f64 re re) #s(literal 1/48 binary64)) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (cos re) #s(literal 1 binary64)) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 #s(literal 1/24 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx re re) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) #s(literal 1/2 binary64)) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
#s(approx (* re re) (*.f64 re re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 1/2 (cos re)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
#s(approx (cos re) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* 2 (cosh 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 (* 2 (cosh im)) (fma.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/360 binary64) #s(literal 1/12 binary64)) (*.f64 im im) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64))) |
#s(approx (cosh im) #s(literal 1 binary64)) |
#s(approx (cosh im) (fma.f64 #s(literal 1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (cosh im) (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/24 binary64) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (cosh im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx im im) |
#s(approx (* 1 (cosh im)) #s(literal 1 binary64)) |
#s(approx (* 1 (cosh im)) (fma.f64 #s(literal 1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (* 1 (cosh im)) (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/24 binary64) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (* 1 (cosh im)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* 2 (cosh 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 (* 2 (cosh im)) (fma.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/360 binary64) #s(literal 1/12 binary64)) (*.f64 im im) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64))) |
#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 (-.f64 (*.f64 #s(literal 1/2 binary64) im) #s(literal 1 binary64)) im #s(literal 1 binary64))) |
#s(approx (exp (neg im)) (fma.f64 (-.f64 (*.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 #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 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (*.f64 (cos.f64 re) #s(literal 1 binary64)) (cos.f64 re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (fma.f64 (-.f64 (*.f64 #s(literal 4/15 binary64) (cos.f64 re)) (fma.f64 #s(literal 1/60 binary64) (cos.f64 re) (*.f64 (*.f64 (cos.f64 re) #s(literal 1 binary64)) #s(literal 1/6 binary64)))) (*.f64 im im) (*.f64 (cos.f64 re) #s(literal 1 binary64)))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (fma.f64 (-.f64 (*.f64 #s(literal 8/315 binary64) (cos.f64 re)) (fma.f64 #s(literal 1/2520 binary64) (cos.f64 re) (fma.f64 #s(literal 1/6 binary64) (-.f64 (*.f64 #s(literal 4/15 binary64) (cos.f64 re)) (fma.f64 #s(literal 1/60 binary64) (cos.f64 re) (*.f64 (*.f64 (cos.f64 re) #s(literal 1 binary64)) #s(literal 1/6 binary64)))) (*.f64 (*.f64 (cos.f64 re) #s(literal 1 binary64)) #s(literal 1/120 binary64))))) (*.f64 im im) (-.f64 (*.f64 #s(literal 4/15 binary64) (cos.f64 re)) (fma.f64 #s(literal 1/60 binary64) (cos.f64 re) (*.f64 (*.f64 (cos.f64 re) #s(literal 1 binary64)) #s(literal 1/6 binary64)))))) (*.f64 im im) (*.f64 (*.f64 (cos.f64 re) #s(literal 1 binary64)) #s(literal 1/2 binary64))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* 2 (cosh 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 (* 2 (cosh im)) (fma.f64 (fma.f64 (fma.f64 (*.f64 im im) #s(literal 1/360 binary64) #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 (* 2 im))) (*.f64 #s(literal -4 binary64) im)) |
#s(approx (- (exp (* (neg im) 2)) (exp (* 2 im))) (*.f64 (-.f64 (*.f64 (*.f64 im im) #s(literal -8/3 binary64)) #s(literal 4 binary64)) im)) |
#s(approx (- (exp (* (neg im) 2)) (exp (* 2 im))) (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 im im) #s(literal -8/15 binary64)) #s(literal 8/3 binary64)) (*.f64 im im)) #s(literal 4 binary64)) im)) |
#s(approx (- (exp (* (neg im) 2)) (exp (* 2 im))) (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 im im) #s(literal -16/315 binary64)) #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 (-.f64 (+.f64 im im) #s(literal 2 binary64)) im #s(literal 1 binary64))) |
#s(approx (exp (* (neg im) 2)) (fma.f64 (-.f64 (*.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 (exp (* 2 im)) #s(literal 1 binary64)) |
#s(approx (exp (* 2 im)) (fma.f64 #s(literal 2 binary64) im #s(literal 1 binary64))) |
#s(approx (exp (* 2 im)) (fma.f64 (fma.f64 #s(literal 2 binary64) im #s(literal 2 binary64)) im #s(literal 1 binary64))) |
#s(approx (exp (* 2 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 (- (exp (neg im)) (exp im)) (*.f64 #s(literal -2 binary64) im)) |
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (-.f64 (*.f64 #s(literal -1/3 binary64) (*.f64 im im)) #s(literal 2 binary64)) im)) |
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 im im) #s(literal -1/60 binary64)) #s(literal 1/3 binary64)) (*.f64 im im)) #s(literal 2 binary64)) im)) |
#s(approx (- (exp (neg im)) (exp im)) (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 im im) #s(literal -1/2520 binary64)) #s(literal 1/60 binary64)) (*.f64 im im)) #s(literal 1/3 binary64)) (*.f64 im im)) #s(literal 2 binary64)) im)) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (cosh im) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
#s(approx (* 1 (cosh im)) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
#s(approx (exp im) (exp.f64 im)) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (- (exp (* (neg im) 2)) (exp (* 2 im))) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))) |
#s(approx (exp (* (neg im) 2)) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))) |
#s(approx (exp (* 2 im)) (exp.f64 (+.f64 im im))) |
#s(approx (- (exp (neg im)) (exp im)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (- (exp (* (neg im) 2)) (exp (* 2 im))) (-.f64 (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64))) (exp.f64 (+.f64 im im)))) |
#s(approx (exp (* (neg im) 2)) (exp.f64 (*.f64 (neg.f64 im) #s(literal 2 binary64)))) |
#s(approx (- (exp (neg im)) (exp im)) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 2 268 to 960 computations (57.7% saved)
11 alts after pruning (9 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 243 | 7 | 250 |
| Fresh | 1 | 2 | 3 |
| Picked | 3 | 2 | 5 |
| Done | 0 | 0 | 0 |
| Total | 247 | 11 | 258 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
| 1.1% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 #s(approx (exp (* (neg im) 2)) #s(literal 1 binary64)) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) | |
| ✓ | 98.9% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
| ✓ | 100.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
| ▶ | 74.7% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| ▶ | 65.0% | (*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
| 71.6% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) | |
| ▶ | 71.7% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
| 48.2% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) | |
| 51.8% | #s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) | |
| ▶ | 30.6% | #s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
Compiled 279 to 265 computations (5% saved)
| Inputs |
|---|
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.f64 re) |
re |
(exp.f64 (neg.f64 im)) |
(neg.f64 im) |
im |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im)) |
(exp.f64 im) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
#s(approx (* 1 (cosh im)) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(literal 1 binary64) (cosh.f64 im)) |
(cosh.f64 im) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(*.f64 re re) |
#s(literal -1/4 binary64) |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
#s(literal 2 binary64) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
(fma.f64 im im #s(literal 2 binary64)) |
| Outputs |
|---|
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (* 1/2 (exp (neg im)))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (* -1/4 (exp (neg im))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (* 1/48 (exp (neg im)))))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (+ (* 1/48 (exp (neg im))) (* (pow re 2) (+ (* -1/1440 (exp im)) (* -1/1440 (exp (neg im))))))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (* 1/2 (exp im)))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (exp im))) (* 1/2 (exp im))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (exp im)) (* (pow re 2) (+ (* -1/4 (exp im)) (* 1/48 (* (pow re 2) (exp im)))))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (exp im)) (* (pow re 2) (+ (* -1/4 (exp im)) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (exp im))) (* 1/48 (exp im))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (neg im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (* 1/2 (* (cos re) (exp im))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* -1/4 (pow re 2)))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/4)))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (cos re))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (* 1/2 (cos re))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* 1/2 (* im (cos re))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* im (+ (* 1/2 (cos re)) (* im (+ (* -1/12 (cos re)) (* 1/12 (cos re)))))))))))) |
#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 (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (cos re)) (* 1/2 (* im (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* 1/4 (* im (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* 1/2 (cos re)) (* im (+ (* 1/12 (* im (cos re))) (* 1/4 (cos re))))))))) |
#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 (cos re)) (* 2 (cosh im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 1)) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (cos re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (cosh im) #s(hole binary64 1)) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 2)) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2))))))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 2)) |
#s(approx (+ (* im im) 2) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im)))) |
#s(approx (exp im) #s(hole binary64 (exp im))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (cosh im) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ (exp im) (/ 1 (exp im))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (pow im 2))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (* (pow im 2) (+ 1 (* 2 (/ 1 (pow im 2))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (* -1 im))))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 3.0ms | im | @ | inf | ((+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (exp (neg im)) (neg im) im (* (* 1/2 (cos re)) (exp im)) (exp im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1 (cosh im)) 1 (* (* 2 (cosh im)) (* 1/2 (cos re))) (* 1 (cosh im)) (cosh im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 2 (cosh im)) (+ (* im im) 2)) |
| 3.0ms | im | @ | -inf | ((+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (exp (neg im)) (neg im) im (* (* 1/2 (cos re)) (exp im)) (exp im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1 (cosh im)) 1 (* (* 2 (cosh im)) (* 1/2 (cos re))) (* 1 (cosh im)) (cosh im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 2 (cosh im)) (+ (* im im) 2)) |
| 3.0ms | re | @ | inf | ((+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (exp (neg im)) (neg im) im (* (* 1/2 (cos re)) (exp im)) (exp im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1 (cosh im)) 1 (* (* 2 (cosh im)) (* 1/2 (cos re))) (* 1 (cosh im)) (cosh im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 2 (cosh im)) (+ (* im im) 2)) |
| 2.0ms | re | @ | -inf | ((+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (exp (neg im)) (neg im) im (* (* 1/2 (cos re)) (exp im)) (exp im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1 (cosh im)) 1 (* (* 2 (cosh im)) (* 1/2 (cos re))) (* 1 (cosh im)) (cosh im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 2 (cosh im)) (+ (* im im) 2)) |
| 2.0ms | re | @ | 0 | ((+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) (* 1/2 (cos re)) 1/2 (cos re) re (exp (neg im)) (neg im) im (* (* 1/2 (cos re)) (exp im)) (exp im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1 (cosh im)) 1 (* (* 2 (cosh im)) (* 1/2 (cos re))) (* 1 (cosh im)) (cosh im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 2 (cosh im)) (+ (* im im) 2)) |
| Inputs |
|---|
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.f64 re) |
re |
(exp.f64 (neg.f64 im)) |
(neg.f64 im) |
im |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im)) |
(exp.f64 im) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
#s(approx (* 1 (cosh im)) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(literal 1 binary64) (cosh.f64 im)) |
(cosh.f64 im) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(*.f64 re re) |
#s(literal -1/4 binary64) |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
#s(literal 2 binary64) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
(fma.f64 im im #s(literal 2 binary64)) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (* 1/2 (exp (neg im)))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (* -1/4 (exp (neg im))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (* 1/48 (exp (neg im)))))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (+ (* 1/48 (exp (neg im))) (* (pow re 2) (+ (* -1/1440 (exp im)) (* -1/1440 (exp (neg im))))))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (* 1/2 (exp im)))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (exp im))) (* 1/2 (exp im))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (exp im)) (* (pow re 2) (+ (* -1/4 (exp im)) (* 1/48 (* (pow re 2) (exp im)))))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (exp im)) (* (pow re 2) (+ (* -1/4 (exp im)) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (exp im))) (* 1/48 (exp im))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (neg im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (* 1/2 (* (cos re) (exp im))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* -1/4 (pow re 2)))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/4)))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (cos re))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (* 1/2 (cos re))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* 1/2 (* im (cos re))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* im (+ (* 1/2 (cos re)) (* im (+ (* -1/12 (cos re)) (* 1/12 (cos re)))))))))))) |
#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 (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (cos re)) (* 1/2 (* im (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* 1/4 (* im (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (exp im)) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* 1/2 (cos re)) (* im (+ (* 1/12 (* im (cos re))) (* 1/4 (cos re))))))))) |
#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 (cos re)) (* 2 (cosh im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 1)) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (cos re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (cosh im) #s(hole binary64 1)) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* 1/2 (pow im 2))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* 1/24 (pow im 2))))))) |
#s(approx (cosh im) #s(hole binary64 (+ 1 (* (pow im 2) (+ 1/2 (* (pow im 2) (+ 1/24 (* 1/720 (pow im 2))))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 2)) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2))))))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 2)) |
#s(approx (+ (* im im) 2) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im)))) |
#s(approx (exp im) #s(hole binary64 (exp im))) |
#s(approx (* 1 (cosh im)) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (cosh im) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ (exp im) (/ 1 (exp im))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (pow im 2))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (* (pow im 2) (+ 1 (* 2 (/ 1 (pow im 2))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp (neg im))) (* (* 1/2 (cos re)) (exp im))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (* -1 im))))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)) (cos.f64 re)) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(literal 2 binary64)) (cosh.f64 im)) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 #s(literal 2 binary64) (*.f64 (cosh.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(*.f64 (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal -1/2 binary64) (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))))) |
(-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (neg.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (exp.f64 im))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))))) (-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))))) |
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) (*.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))))) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) #s(literal 3 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (-.f64 (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) (*.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) #s(literal 3 binary64))) (fma.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))))))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))) #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 (*.f64 (exp.f64 im) (cos.f64 re)) #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
(*.f64 (cos.f64 re) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
(*.f64 #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(neg.f64 #s(literal -1/2 binary64)) |
(cos.f64 re) |
(cos.f64 (neg.f64 re)) |
(sin.f64 (+.f64 re (/.f64 (PI.f64) #s(literal 2 binary64)))) |
re |
(+.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im))) |
(-.f64 (cosh.f64 im) (sinh.f64 im)) |
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 im))) |
(/.f64 #s(literal 1 binary64) (exp.f64 im)) |
(exp.f64 (neg.f64 im)) |
(fma.f64 #s(literal 1 binary64) (cosh.f64 im) (sinh.f64 (neg.f64 im))) |
(fma.f64 (cosh.f64 im) #s(literal 1 binary64) (sinh.f64 (neg.f64 im))) |
(pow.f64 (exp.f64 #s(literal -1 binary64)) im) |
(pow.f64 (exp.f64 im) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) im) |
(*.f64 im #s(literal -1 binary64)) |
(neg.f64 im) |
im |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im)) |
(*.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) |
(*.f64 (*.f64 (exp.f64 im) (cos.f64 re)) #s(literal 1/2 binary64)) |
(+.f64 (cosh.f64 im) (sinh.f64 im)) |
(exp.f64 im) |
(fma.f64 #s(literal 1 binary64) (cosh.f64 im) (sinh.f64 im)) |
(fma.f64 (cosh.f64 im) #s(literal 1 binary64) (sinh.f64 im)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (cosh im) #s(literal 1 binary64))) |
#s(approx (cosh im) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64)) |
(cosh.f64 #s(literal 0 binary64)) |
(exp.f64 #s(literal 0 binary64)) |
(neg.f64 #s(literal -1 binary64)) |
(pow.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cosh.f64 im)) |
(*.f64 #s(literal 1 binary64) (cosh.f64 im)) |
(*.f64 (cosh.f64 im) #s(literal 1 binary64)) |
(/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 2 binary64)) |
(cosh.f64 im) |
(cosh.f64 (neg.f64 im)) |
(*.f64 #s(literal 1 binary64) (cosh.f64 im)) |
(*.f64 (cosh.f64 im) #s(literal 1 binary64)) |
(/.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 2 binary64)) |
(cosh.f64 im) |
(cosh.f64 (neg.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* 1/2 (cos re)) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) |
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) |
(+.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) |
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) (*.f64 re re))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) #s(literal 1/4 binary64)) (-.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64))) |
(/.f64 (+.f64 (pow.f64 #s(literal 1/2 binary64) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 3 binary64)) (pow.f64 #s(literal 1/2 binary64) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64))))) |
(fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64)) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(fma.f64 re (*.f64 re #s(literal -1/4 binary64)) #s(literal 1/2 binary64)) |
(*.f64 re re) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 (pow.f64 re (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 re (/.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) |
(pow.f64 re #s(literal 2 binary64)) |
#s(literal -1/4 binary64) |
(neg.f64 #s(literal 1/4 binary64)) |
(*.f64 #s(literal 2 binary64) (cosh.f64 im)) |
(*.f64 (cosh.f64 im) #s(literal 2 binary64)) |
(+.f64 (exp.f64 im) (exp.f64 (neg.f64 im))) |
(+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
(+.f64 (cosh.f64 im) (cosh.f64 im)) |
(/.f64 (-.f64 (*.f64 (exp.f64 im) (exp.f64 im)) (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im)))) (-.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 im) #s(literal 3 binary64)) (pow.f64 (exp.f64 (neg.f64 im)) #s(literal 3 binary64))) (fma.f64 (exp.f64 im) (exp.f64 im) (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 (neg.f64 im)))))) |
(fma.f64 #s(literal 1 binary64) (cosh.f64 im) (cosh.f64 im)) |
(fma.f64 (cosh.f64 im) #s(literal 1 binary64) (cosh.f64 im)) |
#s(literal 2 binary64) |
(*.f64 #s(literal 2 binary64) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) #s(literal 1 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
(+.f64 #s(literal 2 binary64) (*.f64 im im)) |
(+.f64 (*.f64 im im) #s(literal 2 binary64)) |
(/.f64 (-.f64 (*.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (*.f64 (*.f64 im im) (*.f64 im im))) (-.f64 #s(literal 2 binary64) (*.f64 im im))) |
(/.f64 (-.f64 (*.f64 (*.f64 im im) (*.f64 im im)) (*.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (-.f64 (*.f64 im im) #s(literal 2 binary64))) |
(/.f64 (+.f64 (pow.f64 #s(literal 2 binary64) #s(literal 3 binary64)) (pow.f64 (*.f64 im im) #s(literal 3 binary64))) (fma.f64 #s(literal 2 binary64) #s(literal 2 binary64) (-.f64 (*.f64 (*.f64 im im) (*.f64 im im)) (*.f64 #s(literal 2 binary64) (*.f64 im im))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 im im) #s(literal 3 binary64)) (pow.f64 #s(literal 2 binary64) #s(literal 3 binary64))) (fma.f64 (*.f64 im im) (*.f64 im im) (-.f64 (*.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (*.f64 (*.f64 im im) #s(literal 2 binary64))))) |
(fma.f64 im im #s(literal 2 binary64)) |
(fma.f64 (neg.f64 im) (neg.f64 im) #s(literal 2 binary64)) |
(fma.f64 (fabs.f64 im) (fabs.f64 im) #s(literal 2 binary64)) |
(fma.f64 (pow.f64 im (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 im (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) #s(literal 2 binary64)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 re re)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (fma.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 re re))) (*.f64 re re)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (fma.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (fma.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 re re))) (*.f64 re re))) (*.f64 re re)))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 1/2 (cos re)) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/1440 binary64) (*.f64 re re) #s(literal 1/48 binary64)) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (cos re) #s(literal 1 binary64)) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 #s(literal 1/24 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx re re) |
#s(approx (* 1/2 (* (cos re) (exp im))) (*.f64 #s(literal 1/2 binary64) (exp.f64 im))) |
#s(approx (* 1/2 (* (cos re) (exp im))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (exp.f64 im)))) |
#s(approx (* 1/2 (* (cos re) (exp im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (exp.f64 im) (*.f64 #s(literal -1/4 binary64) (exp.f64 im))) (*.f64 re re) (*.f64 #s(literal 1/2 binary64) (exp.f64 im)))) |
#s(approx (* 1/2 (* (cos re) (exp im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (exp.f64 im) (*.f64 #s(literal 1/48 binary64) (exp.f64 im))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (exp.f64 im))) (*.f64 re re) (*.f64 #s(literal 1/2 binary64) (exp.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) #s(literal 1/2 binary64)) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* re re) (*.f64 re re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 1/2 (cos re)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
#s(approx (cos re) (cos.f64 re)) |
#s(approx (* 1/2 (* (cos re) (exp im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 (cos.f64 re) #s(literal 0 binary64)) im (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (cos.f64 re) #s(literal 0 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) im) (cos.f64 re))) im (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (cos.f64 re) #s(literal 0 binary64) (*.f64 (fma.f64 (*.f64 (cos.f64 re) #s(literal 0 binary64)) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) im)) im (cos.f64 re))) |
#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 (-.f64 (*.f64 #s(literal 1/2 binary64) im) #s(literal 1 binary64)) im #s(literal 1 binary64))) |
#s(approx (exp (neg im)) (fma.f64 (-.f64 (*.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 (* 1/2 (* (cos re) (exp im))) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
#s(approx (* 1/2 (* (cos re) (exp im))) (*.f64 #s(literal 1/2 binary64) (+.f64 (cos.f64 re) (*.f64 (cos.f64 re) im)))) |
#s(approx (* 1/2 (* (cos re) (exp im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/4 binary64) im) (cos.f64 re) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
#s(approx (* 1/2 (* (cos re) (exp im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/12 binary64) im) (cos.f64 re) (*.f64 #s(literal 1/4 binary64) (cos.f64 re))) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
#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 (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (cosh im) #s(literal 1 binary64)) |
#s(approx (cosh im) (fma.f64 #s(literal 1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (cosh im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (cosh im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (cosh im) #s(literal 1 binary64)) |
#s(approx (cosh im) (fma.f64 #s(literal 1/2 binary64) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (cosh im) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 im im) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (cosh im) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/720 binary64) (*.f64 im im) #s(literal 1/24 binary64)) (*.f64 im im) #s(literal 1/2 binary64)) (*.f64 im im) #s(literal 1 binary64))) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* 2 (cosh im)) (fma.f64 (fma.f64 #s(literal 1/12 binary64) (*.f64 im im) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64))) |
#s(approx (* 2 (cosh 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 (+ 2 (* im im)) #s(literal 2 binary64)) |
#s(approx (+ 2 (* im im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
#s(approx (exp im) (exp.f64 im)) |
#s(approx (cosh im) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (cosh im) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (+ 2 (* im im)) (*.f64 im im)) |
#s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
Compiled 1 582 to 647 computations (59.1% saved)
14 alts after pruning (10 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 175 | 7 | 182 |
| Fresh | 1 | 3 | 4 |
| Picked | 3 | 2 | 5 |
| Done | 0 | 2 | 2 |
| Total | 179 | 14 | 193 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 100.0% | (fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
| 1.1% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 #s(approx (exp (* (neg im) 2)) #s(literal 1 binary64)) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) | |
| ✓ | 98.9% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
| ✓ | 100.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
| ✓ | 74.7% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| 30.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) | |
| ▶ | 49.1% | (*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| ▶ | 32.6% | (*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
| 11.0% | (*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) | |
| 71.6% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) | |
| ▶ | 51.8% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| 71.7% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) | |
| ▶ | 48.2% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
| ✓ | 30.6% | #s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
Compiled 344 to 335 computations (2.6% saved)
| Inputs |
|---|
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.f64 re) |
re |
(exp.f64 im) |
im |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) |
(exp.f64 (neg.f64 im)) |
(neg.f64 im) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
(fma.f64 im im #s(literal 2 binary64)) |
#s(literal 2 binary64) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(*.f64 re re) |
#s(literal -1/4 binary64) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
(fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)) |
#s(literal -1/2 binary64) |
#s(literal 1 binary64) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
| Outputs |
|---|
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (* 1/2 (exp (neg im)))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (* -1/4 (exp (neg im))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (* 1/48 (exp (neg im)))))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (+ (* 1/48 (exp (neg im))) (* (pow re 2) (+ (* -1/1440 (exp im)) (* -1/1440 (exp (neg im))))))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (exp (neg im))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (exp (neg im)))) (* 1/2 (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp (neg im))) (* 1/48 (* (pow re 2) (exp (neg im))))))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (exp (neg im)))) (* 1/48 (exp (neg im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 1)) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (neg im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (* (cos re) (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* -1/4 (pow re 2)))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/4)))) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 (* -1/2 (pow re 2)))) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 (* (pow re 2) (- (/ 1 (pow re 2)) 1/2)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (cos re))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (* 1/2 (cos re))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* 1/2 (* im (cos re))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* im (+ (* 1/2 (cos re)) (* im (+ (* -1/12 (cos re)) (* 1/12 (cos re)))))))))))) |
#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 im #s(hole binary64 im)) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* -1/2 (* im (cos re))) (* 1/2 (cos re))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* -1/2 (cos re)) (* 1/4 (* im (cos re)))))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* -1/2 (cos re)) (* im (+ (* -1/12 (* im (cos re))) (* 1/4 (cos re))))))))) |
#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 (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 2)) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2))))))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 2)) |
#s(approx (+ (* im im) 2) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (cos re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (exp im) #s(hole binary64 (exp im))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ (exp im) (/ 1 (exp im))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (pow im 2))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (* (pow im 2) (+ 1 (* 2 (/ 1 (pow im 2))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (* -1 im))))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (* (cos re) (exp (* -1 im)))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | re | @ | inf | ((+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) (* 1/2 (cos re)) 1/2 (cos re) re (exp im) im (* (* 1/2 (cos re)) (exp (neg im))) (exp (neg im)) (neg im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (* 2 (cosh im)) (+ (* im im) 2) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (cos re) (+ (* -1/2 (* re re)) 1) -1/2 1 (* (* 2 (cosh im)) (* 1/2 (cos re)))) |
| 2.0ms | im | @ | -inf | ((+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) (* 1/2 (cos re)) 1/2 (cos re) re (exp im) im (* (* 1/2 (cos re)) (exp (neg im))) (exp (neg im)) (neg im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (* 2 (cosh im)) (+ (* im im) 2) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (cos re) (+ (* -1/2 (* re re)) 1) -1/2 1 (* (* 2 (cosh im)) (* 1/2 (cos re)))) |
| 2.0ms | re | @ | -inf | ((+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) (* 1/2 (cos re)) 1/2 (cos re) re (exp im) im (* (* 1/2 (cos re)) (exp (neg im))) (exp (neg im)) (neg im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (* 2 (cosh im)) (+ (* im im) 2) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (cos re) (+ (* -1/2 (* re re)) 1) -1/2 1 (* (* 2 (cosh im)) (* 1/2 (cos re)))) |
| 2.0ms | im | @ | inf | ((+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) (* 1/2 (cos re)) 1/2 (cos re) re (exp im) im (* (* 1/2 (cos re)) (exp (neg im))) (exp (neg im)) (neg im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (* 2 (cosh im)) (+ (* im im) 2) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (cos re) (+ (* -1/2 (* re re)) 1) -1/2 1 (* (* 2 (cosh im)) (* 1/2 (cos re)))) |
| 1.0ms | re | @ | 0 | ((+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) (* 1/2 (cos re)) 1/2 (cos re) re (exp im) im (* (* 1/2 (cos re)) (exp (neg im))) (exp (neg im)) (neg im) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (* 2 (cosh im)) (+ (* im im) 2) 2 (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (+ (* (* re re) -1/4) 1/2) (* re re) -1/4 (* 2 (cosh im)) (* (* 1/2 (cos re)) (* 2 (cosh im))) (* 1/2 (cos re)) (cos re) (+ (* -1/2 (* re re)) 1) -1/2 1 (* (* 2 (cosh im)) (* 1/2 (cos re)))) |
| Inputs |
|---|
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
#s(literal 1/2 binary64) |
(cos.f64 re) |
re |
(exp.f64 im) |
im |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) |
(exp.f64 (neg.f64 im)) |
(neg.f64 im) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
(fma.f64 im im #s(literal 2 binary64)) |
#s(literal 2 binary64) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(*.f64 re re) |
#s(literal -1/4 binary64) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
(fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)) |
#s(literal -1/2 binary64) |
#s(literal 1 binary64) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (* 1/2 (exp (neg im)))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (* -1/4 (exp (neg im))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (* 1/48 (exp (neg im)))))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (exp im)) (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp im)) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* 1/48 (exp im)) (+ (* 1/48 (exp (neg im))) (* (pow re 2) (+ (* -1/1440 (exp im)) (* -1/1440 (exp (neg im))))))))))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 1/2)) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* 1/48 (pow re 2)) 1/4))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (+ 1/2 (* (pow re 2) (- (* (pow re 2) (+ 1/48 (* -1/1440 (pow re 2)))) 1/4))))) |
#s(approx (cos re) #s(hole binary64 1)) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* 1/24 (pow re 2)) 1/2))))) |
#s(approx (cos re) #s(hole binary64 (+ 1 (* (pow re 2) (- (* (pow re 2) (+ 1/24 (* -1/720 (pow re 2)))) 1/2))))) |
#s(approx re #s(hole binary64 re)) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (exp (neg im))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (exp (neg im)))) (* 1/2 (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp (neg im))) (* 1/48 (* (pow re 2) (exp (neg im))))))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (exp (neg im))) (* (pow re 2) (+ (* -1/4 (exp (neg im))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (exp (neg im)))) (* 1/48 (exp (neg im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 (pow re 2))))) |
#s(approx (* re re) #s(hole binary64 (pow re 2))) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 1)) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 (+ 1 (* -1/2 (pow re 2))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (+ (exp im) (/ 1 (exp im)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* -1/4 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/2 (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* 1/48 (* (pow re 2) (+ (exp im) (/ 1 (exp im)))))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (* 1/2 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/4 (+ (exp im) (/ 1 (exp im)))) (* (pow re 2) (+ (* -1/1440 (* (pow re 2) (+ (exp im) (/ 1 (exp im))))) (* 1/48 (+ (exp im) (/ 1 (exp im))))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (neg im))))))) |
#s(approx (* 1/2 (cos re)) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (cos re) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (* (cos re) (exp (neg im)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* -1/4 (pow re 2)))) |
#s(approx (+ (* (* re re) -1/4) 1/2) #s(hole binary64 (* (pow re 2) (- (* 1/2 (/ 1 (pow re 2))) 1/4)))) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 (* -1/2 (pow re 2)))) |
#s(approx (+ (* -1/2 (* re re)) 1) #s(hole binary64 (* (pow re 2) (- (/ 1 (pow re 2)) 1/2)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (* 1/2 (* (cos re) (+ (exp im) (/ 1 (exp im))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (cos re))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (* 1/2 (cos re))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* 1/2 (* im (cos re))))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (cos re) (* im (+ (* -1/2 (cos re)) (+ (* 1/2 (cos re)) (* im (+ (* 1/2 (cos re)) (* im (+ (* -1/12 (cos re)) (* 1/12 (cos re)))))))))))) |
#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 im #s(hole binary64 im)) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (cos re)))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* -1/2 (* im (cos re))) (* 1/2 (cos re))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* -1/2 (cos re)) (* 1/4 (* im (cos re)))))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (+ (* 1/2 (cos re)) (* im (+ (* -1/2 (cos re)) (* im (+ (* -1/12 (* im (cos re))) (* 1/4 (cos re))))))))) |
#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 (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (cos re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 2)) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* 1/12 (pow im 2))))))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ 2 (* (pow im 2) (+ 1 (* (pow im 2) (+ 1/12 (* 1/360 (pow im 2))))))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 2)) |
#s(approx (+ (* im im) 2) #s(hole binary64 (+ 2 (pow im 2)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (cos re))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* 1/2 (* (pow im 2) (cos re)))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/24 (* (pow im 2) (cos re))) (* 1/2 (cos re))))))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(hole binary64 (+ (cos re) (* (pow im 2) (+ (* 1/2 (cos re)) (* (pow im 2) (+ (* 1/720 (* (pow im 2) (cos re))) (* 1/24 (cos re))))))))) |
#s(approx (exp im) #s(hole binary64 (exp im))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (neg im)))) |
#s(approx (* 2 (cosh im)) #s(hole binary64 (+ (exp im) (/ 1 (exp im))))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (pow im 2))) |
#s(approx (+ (* im im) 2) #s(hole binary64 (* (pow im 2) (+ 1 (* 2 (/ 1 (pow im 2))))))) |
#s(approx (+ (* (* 1/2 (cos re)) (exp im)) (* (* 1/2 (cos re)) (exp (neg im)))) #s(hole binary64 (+ (* 1/2 (* (cos re) (exp im))) (* 1/2 (* (cos re) (exp (* -1 im))))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) #s(hole binary64 (* 1/2 (* (cos re) (exp (* -1 im)))))) |
#s(approx (exp (neg im)) #s(hole binary64 (exp (* -1 im)))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)) (cos.f64 re)) |
(*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(literal 2 binary64)) (cosh.f64 im)) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 #s(literal 2 binary64) (*.f64 (cosh.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
(*.f64 (*.f64 (cos.f64 re) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(+.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal -1/2 binary64) (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))))) |
(-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (neg.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (exp.f64 (neg.f64 im)))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))))) (-.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) #s(literal 3 binary64)) (pow.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (-.f64 (*.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) (*.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))))))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 (exp.f64 im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))) #s(literal 1/2 binary64) (*.f64 #s(literal 1/2 binary64) (*.f64 (exp.f64 im) (cos.f64 re)))) |
(fma.f64 (*.f64 (exp.f64 im) (cos.f64 re)) #s(literal 1/2 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
(*.f64 (cos.f64 re) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
(*.f64 #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(neg.f64 #s(literal -1/2 binary64)) |
(cos.f64 re) |
(cos.f64 (neg.f64 re)) |
(sin.f64 (+.f64 re (/.f64 (PI.f64) #s(literal 2 binary64)))) |
re |
(+.f64 (cosh.f64 im) (sinh.f64 im)) |
(exp.f64 im) |
im |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im))) |
(*.f64 (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
(*.f64 #s(literal 1/2 binary64) (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im)))) |
(*.f64 (*.f64 (cos.f64 re) (exp.f64 (neg.f64 im))) #s(literal 1/2 binary64)) |
(+.f64 (cosh.f64 im) (sinh.f64 (neg.f64 im))) |
(-.f64 (cosh.f64 im) (sinh.f64 im)) |
(/.f64 #s(literal -1 binary64) (neg.f64 (exp.f64 im))) |
(/.f64 #s(literal 1 binary64) (exp.f64 im)) |
(exp.f64 (neg.f64 im)) |
(pow.f64 (exp.f64 #s(literal -1 binary64)) im) |
(pow.f64 (exp.f64 im) #s(literal -1 binary64)) |
(*.f64 #s(literal -1 binary64) im) |
(*.f64 im #s(literal -1 binary64)) |
(neg.f64 im) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
(+.f64 #s(literal 2 binary64) (*.f64 im im)) |
(+.f64 (*.f64 im im) #s(literal 2 binary64)) |
(/.f64 (-.f64 (*.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (*.f64 (*.f64 im im) (*.f64 im im))) (-.f64 #s(literal 2 binary64) (*.f64 im im))) |
(/.f64 (-.f64 (*.f64 (*.f64 im im) (*.f64 im im)) (*.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (-.f64 (*.f64 im im) #s(literal 2 binary64))) |
(/.f64 (+.f64 (pow.f64 #s(literal 2 binary64) #s(literal 3 binary64)) (pow.f64 (*.f64 im im) #s(literal 3 binary64))) (fma.f64 #s(literal 2 binary64) #s(literal 2 binary64) (-.f64 (*.f64 (*.f64 im im) (*.f64 im im)) (*.f64 #s(literal 2 binary64) (*.f64 im im))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 im im) #s(literal 3 binary64)) (pow.f64 #s(literal 2 binary64) #s(literal 3 binary64))) (fma.f64 (*.f64 im im) (*.f64 im im) (-.f64 (*.f64 #s(literal 2 binary64) #s(literal 2 binary64)) (*.f64 (*.f64 im im) #s(literal 2 binary64))))) |
(fma.f64 im im #s(literal 2 binary64)) |
(fma.f64 (neg.f64 im) (neg.f64 im) #s(literal 2 binary64)) |
(fma.f64 (fabs.f64 im) (fabs.f64 im) #s(literal 2 binary64)) |
(fma.f64 (pow.f64 im (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 im (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) #s(literal 2 binary64)) |
#s(literal 2 binary64) |
(*.f64 #s(literal 2 binary64) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) #s(literal 1 binary64)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) |
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) |
(+.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) |
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) (*.f64 re re))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) #s(literal 1/4 binary64)) (-.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64))) |
(/.f64 (+.f64 (pow.f64 #s(literal 1/2 binary64) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 3 binary64)) (pow.f64 #s(literal 1/2 binary64) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) #s(literal 1/2 binary64))))) |
(fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64)) |
(fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64)) |
(fma.f64 re (*.f64 re #s(literal -1/4 binary64)) #s(literal 1/2 binary64)) |
(*.f64 re re) |
(*.f64 (fabs.f64 re) (fabs.f64 re)) |
(*.f64 (neg.f64 re) (neg.f64 re)) |
(*.f64 (pow.f64 re (/.f64 #s(literal 2 binary64) #s(literal 2 binary64))) (pow.f64 re (/.f64 #s(literal 2 binary64) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) |
(pow.f64 re #s(literal 2 binary64)) |
#s(literal -1/4 binary64) |
(neg.f64 #s(literal 1/4 binary64)) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))) |
(+.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) #s(literal 1 binary64)) |
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) (*.f64 re re))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) (*.f64 #s(literal -1/2 binary64) (*.f64 re re)))) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 re re)))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))) #s(literal 1 binary64)) (-.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) #s(literal 1 binary64))) |
(/.f64 (+.f64 #s(literal 1 binary64) (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) #s(literal 3 binary64))) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) (*.f64 re re)))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) #s(literal 3 binary64)) #s(literal 1 binary64)) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 re re)) #s(literal 1 binary64))))) |
(fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)) |
(fma.f64 (*.f64 re re) #s(literal -1/2 binary64) #s(literal 1 binary64)) |
(fma.f64 (*.f64 #s(literal -1/2 binary64) re) re #s(literal 1 binary64)) |
#s(literal -1/2 binary64) |
(neg.f64 #s(literal 1/2 binary64)) |
#s(literal 1 binary64) |
(*.f64 #s(literal 1 binary64) #s(literal 1 binary64)) |
(cosh.f64 #s(literal 0 binary64)) |
(exp.f64 #s(literal 0 binary64)) |
(neg.f64 #s(literal -1 binary64)) |
(pow.f64 #s(literal 1 binary64) #s(literal 3 binary64)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 re re)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (fma.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 re re))) (*.f64 re re)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (fma.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (fma.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) (*.f64 re re))) (*.f64 re re))) (*.f64 re re)))) |
#s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) |
#s(approx (* 1/2 (cos re)) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* 1/2 (cos re)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/1440 binary64) (*.f64 re re) #s(literal 1/48 binary64)) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (cos re) #s(literal 1 binary64)) |
#s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 #s(literal 1/24 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx re re) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (*.f64 #s(literal 1/2 binary64) (exp.f64 (neg.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/2 binary64) (exp.f64 (neg.f64 im))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (exp.f64 (neg.f64 im)) (*.f64 #s(literal -1/4 binary64) (exp.f64 (neg.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1/2 binary64) (exp.f64 (neg.f64 im))))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (exp.f64 (neg.f64 im)) (*.f64 #s(literal 1/48 binary64) (exp.f64 (neg.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (exp.f64 (neg.f64 im)))) (*.f64 re re) (*.f64 #s(literal 1/2 binary64) (exp.f64 (neg.f64 im))))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) #s(literal 1/2 binary64)) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (fma.f64 #s(literal -1/4 binary64) (*.f64 re re) #s(literal 1/2 binary64))) |
#s(approx (* re re) (*.f64 re re)) |
#s(approx (+ 1 (* -1/2 (* re re))) #s(literal 1 binary64)) |
#s(approx (+ 1 (* -1/2 (* re re))) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal -1/4 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/1440 binary64) (*.f64 re re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)) (*.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 #s(literal -1/4 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) (*.f64 re re) (*.f64 (*.f64 #s(literal 2 binary64) (cosh.f64 im)) #s(literal 1/2 binary64)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* 1/2 (cos re)) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
#s(approx (cos re) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re))) |
#s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 re re)) #s(literal 1/4 binary64)) (*.f64 re re))) |
#s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))) |
#s(approx (+ 1 (* -1/2 (* re re))) (*.f64 (-.f64 (/.f64 #s(literal 1 binary64) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 (cos.f64 re) #s(literal 0 binary64)) im (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (cos.f64 re) #s(literal 0 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) im) (cos.f64 re))) im (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (cos.f64 re) #s(literal 0 binary64) (*.f64 (fma.f64 (*.f64 (cos.f64 re) #s(literal 0 binary64)) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) im)) im (cos.f64 re))) |
#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 im im) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (fma.f64 #s(literal 1/2 binary64) (cos.f64 re) (*.f64 #s(literal -1/2 binary64) (*.f64 (cos.f64 re) im)))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (fma.f64 (fma.f64 #s(literal 1/4 binary64) (*.f64 (cos.f64 re) im) (*.f64 #s(literal -1/2 binary64) (cos.f64 re))) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal -1/12 binary64) im) (cos.f64 re) (*.f64 #s(literal 1/4 binary64) (cos.f64 re))) im (*.f64 #s(literal -1/2 binary64) (cos.f64 re))) im (*.f64 #s(literal 1/2 binary64) (cos.f64 re)))) |
#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 (-.f64 (*.f64 #s(literal 1/2 binary64) im) #s(literal 1 binary64)) im #s(literal 1 binary64))) |
#s(approx (exp (neg im)) (fma.f64 (-.f64 (*.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 (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* 2 (cosh im)) #s(literal 2 binary64)) |
#s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* 2 (cosh im)) (fma.f64 (fma.f64 #s(literal 1/12 binary64) (*.f64 im im) #s(literal 1 binary64)) (*.f64 im im) #s(literal 2 binary64))) |
#s(approx (* 2 (cosh 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 (+ 2 (* im im)) #s(literal 2 binary64)) |
#s(approx (+ 2 (* im im)) (fma.f64 im im #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 im im)) (cos.f64 re) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (*.f64 (*.f64 im im) (cos.f64 re)) #s(literal 1/24 binary64) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (fma.f64 (fma.f64 (fma.f64 (*.f64 #s(literal 1/720 binary64) (*.f64 im im)) (cos.f64 re) (*.f64 #s(literal 1/24 binary64) (cos.f64 re))) (*.f64 im im) (*.f64 #s(literal 1/2 binary64) (cos.f64 re))) (*.f64 im im) (cos.f64 re))) |
#s(approx (exp im) (exp.f64 im)) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
#s(approx (* 2 (cosh im)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (+ 2 (* im im)) (*.f64 im im)) |
#s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
#s(approx (* (* 1/2 (cos re)) (exp (neg im))) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
#s(approx (exp (neg im)) (exp.f64 (neg.f64 im))) |
Compiled 1 632 to 703 computations (56.9% saved)
19 alts after pruning (11 fresh and 8 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 176 | 6 | 182 |
| Fresh | 0 | 5 | 5 |
| Picked | 1 | 4 | 5 |
| Done | 0 | 4 | 4 |
| Total | 177 | 19 | 196 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 100.0% | (fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
| 1.1% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 #s(approx (exp (* (neg im) 2)) #s(literal 1 binary64)) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) | |
| ✓ | 98.9% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
| ✓ | 100.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
| ✓ | 74.7% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| 30.0% | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) | |
| 10.1% | (*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) | |
| ✓ | 32.6% | (*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
| 32.6% | (*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) | |
| 11.0% | (*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) | |
| 6.2% | (*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) | |
| 71.6% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) | |
| ✓ | 51.8% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| 37.5% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) | |
| 24.5% | (*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) | |
| 71.7% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) | |
| ✓ | 48.2% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
| 36.6% | #s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) | |
| ✓ | 30.6% | #s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
Compiled 512 to 411 computations (19.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 #s(approx (exp (* (neg im) 2)) #s(literal 1 binary64)) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 (*.f64 (exp.f64 (neg.f64 im)) (exp.f64 (neg.f64 im))) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) |
| Outputs |
|---|
(fma.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 im) (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (exp.f64 (neg.f64 im)))) |
6 calls:
| 66.0ms | im |
| 13.0ms | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 11.0ms | (cos.f64 re) |
| 8.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 8.0ms | re |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 100.0% | 1 | (cos.f64 re) |
| 100.0% | 1 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 100.0% | 1 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 100.0% | 1 | re |
| 100.0% | 1 | im |
Compiled 23 to 28 computations (-21.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (/.f64 (-.f64 #s(approx (exp (* (neg im) 2)) #s(literal 1 binary64)) (*.f64 (exp.f64 im) (exp.f64 im))) (-.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
6 calls:
| 25.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 25.0ms | im |
| 11.0ms | (cos.f64 re) |
| 8.0ms | re |
| 7.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| Accuracy | Segments | Branch |
|---|---|---|
| 100.0% | 1 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 100.0% | 1 | (cos.f64 re) |
| 100.0% | 1 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 100.0% | 1 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 100.0% | 1 | re |
| 100.0% | 1 | im |
Compiled 23 to 28 computations (-21.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
6 calls:
| 8.0ms | (cos.f64 re) |
| 6.0ms | re |
| 6.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 6.0ms | im |
| 5.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.9% | 1 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 98.9% | 1 | (cos.f64 re) |
| 98.9% | 1 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 98.9% | 1 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 98.9% | 1 | re |
| 98.9% | 1 | im |
Compiled 23 to 28 computations (-21.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
6 calls:
| 27.0ms | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 6.0ms | re |
| 6.0ms | im |
| 5.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 5.0ms | (cos.f64 re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 89.3% | 2 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 89.6% | 2 | (cos.f64 re) |
| 89.6% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 99.1% | 3 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 89.5% | 2 | re |
| 94.4% | 3 | im |
Compiled 23 to 28 computations (-21.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cos.f64 re)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (cos.f64 re)) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
1 calls:
| 5.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.9% | 3 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 10 to 10 computations (0% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (exp.f64 (*.f64 (log.f64 re) #s(literal 2 binary64))) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
6 calls:
| 22.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 6.0ms | im |
| 5.0ms | re |
| 5.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 5.0ms | (cos.f64 re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 71.7% | 1 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 71.7% | 1 | re |
| 81.8% | 2 | (cos.f64 re) |
| 81.8% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 71.7% | 1 | im |
| 81.8% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 23 to 28 computations (-21.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) #s(approx (cos re) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/720 binary64) (*.f64 re re) #s(literal 1/24 binary64)) (*.f64 re re)) #s(literal 1/2 binary64)) (*.f64 re re) #s(literal 1 binary64)))) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) (*.f64 #s(literal 2 binary64) (cosh.f64 im))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
3 calls:
| 7.0ms | (cos.f64 re) |
| 7.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 7.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 81.8% | 2 | (cos.f64 re) |
| 81.8% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 81.8% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 16 to 18 computations (-12.5% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) (fma.f64 #s(literal -1/2 binary64) (*.f64 re re) #s(literal 1 binary64)))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
3 calls:
| 7.0ms | (cos.f64 re) |
| 7.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 6.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 80.7% | 2 | (cos.f64 re) |
| 80.7% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 80.7% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 16 to 18 computations (-12.5% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 (+.f64 #s(literal 1 binary64) (/.f64 #s(literal 2 binary64) (*.f64 im im))) (*.f64 im im))))) |
| Outputs |
|---|
(*.f64 (*.f64 #s(literal 1/2 binary64) #s(approx (cos re) #s(approx (+ 1 (* -1/2 (* re re))) (*.f64 #s(literal -1/2 binary64) (*.f64 re re))))) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
3 calls:
| 5.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 3.0ms | (cos.f64 re) |
| 3.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 80.7% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 80.7% | 2 | (cos.f64 re) |
| 80.7% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
Compiled 16 to 18 computations (-12.5% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (*.f64 #s(literal 1 binary64) (cosh.f64 im))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) (+.f64 #s(approx (exp (neg im)) #s(literal 1 binary64)) (exp.f64 im))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 2 binary64) (cosh.f64 im)))) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) (fma.f64 (*.f64 re re) #s(literal -1/4 binary64) #s(literal 1/2 binary64))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
3 calls:
| 3.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 3.0ms | (cos.f64 re) |
| 3.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 76.6% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 76.6% | 2 | (cos.f64 re) |
| 76.6% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
Compiled 16 to 18 computations (-12.5% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 2 (cosh im)) (* 1/2 (cos re))) (cosh.f64 im)) |
3 calls:
| 19.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 3.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 3.0ms | (cos.f64 re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 76.6% | 2 | (cos.f64 re) |
| 76.6% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 76.6% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 16 to 18 computations (-12.5% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
| Outputs |
|---|
(*.f64 #s(approx (* 1/2 (cos re)) #s(approx (+ 1/2 (* -1/4 (* re re))) (*.f64 #s(literal -1/4 binary64) (*.f64 re re)))) #s(approx (* 2 (cosh im)) #s(literal 2 binary64))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
6 calls:
| 4.0ms | (cos.f64 re) |
| 2.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 2.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 2.0ms | re |
| 2.0ms | im |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.8% | 1 | re |
| 51.8% | 1 | im |
| 51.8% | 1 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 56.7% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 56.7% | 2 | (cos.f64 re) |
| 56.7% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
Compiled 23 to 28 computations (-21.7% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64)))) |
| Outputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) (*.f64 #s(literal 1/2 binary64) #s(approx (* 2 (cosh im)) (fma.f64 im im #s(literal 2 binary64))))) |
4 calls:
| 2.0ms | re |
| 2.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 2.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 2.0ms | (cos.f64 re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.8% | 1 | re |
| 51.8% | 1 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 51.8% | 1 | (cos.f64 re) |
| 51.8% | 1 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
Compiled 17 to 20 computations (-17.6% saved)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
| Outputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
(*.f64 #s(approx (* 1/2 (cos re)) #s(literal 1/2 binary64)) #s(approx (* 2 (cosh im)) #s(approx (+ 2 (* im im)) (*.f64 im im)))) |
6 calls:
| 2.0ms | re |
| 2.0ms | im |
| 2.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 1.0ms | (cos.f64 re) |
| 1.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.8% | 2 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 37.6% | 2 | (cos.f64 re) |
| 37.6% | 2 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 51.8% | 2 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 51.8% | 2 | im |
| 39.6% | 3 | re |
Compiled 23 to 28 computations (-21.7% saved)
Total -0.0b remaining (-0%)
Threshold costs -0b (-0%)
| Inputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
| Outputs |
|---|
#s(approx (* (* 1/2 (cos re)) (* 2 (cosh im))) #s(approx (* 1 (cosh im)) #s(literal 1 binary64))) |
6 calls:
| 1.0ms | im |
| 1.0ms | re |
| 1.0ms | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 1.0ms | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
| 1.0ms | (cos.f64 re) |
| Accuracy | Segments | Branch |
|---|---|---|
| 30.6% | 1 | (cos.f64 re) |
| 30.6% | 1 | (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) |
| 30.6% | 1 | re |
| 30.6% | 1 | im |
| 30.6% | 1 | (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im)) |
| 30.6% | 1 | (*.f64 (*.f64 #s(literal 1/2 binary64) (cos.f64 re)) (+.f64 (exp.f64 (neg.f64 im)) (exp.f64 im))) |
Compiled 23 to 28 computations (-21.7% saved)
| 2× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 0.9995808683165069 | 1.0 |
| 0.0ms | -inf | -4.590645447174061e+39 |
Compiled 13 to 15 computations (-15.4% saved)
| 2× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 0.9995808683165069 | 1.0 |
| 0.0ms | -inf | -4.590645447174061e+39 |
Compiled 13 to 15 computations (-15.4% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.019182116107382605 | 0.1335517793004728 |
Compiled 13 to 15 computations (-15.4% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.019182116107382605 | 0.1335517793004728 |
Compiled 13 to 15 computations (-15.4% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.009591058053691303 | 0.010422950729697143 |
Compiled 14 to 15 computations (-7.1% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.009591058053691303 | 0.010422950729697143 |
Compiled 14 to 15 computations (-7.1% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.009591058053691303 | 0.010422950729697143 |
Compiled 14 to 15 computations (-7.1% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.009591058053691303 | 0.010422950729697143 |
Compiled 14 to 15 computations (-7.1% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | -0.009591058053691303 | 0.010422950729697143 |
Compiled 14 to 15 computations (-7.1% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 1.0 | 7.082079913800547e+107 |
Compiled 13 to 15 computations (-15.4% saved)
| 1× | fuel |
Compiled 158 to 98 computations (38% saved)
(abs im)
(abs re)
Compiled 1 896 to 1 640 computations (13.5% saved)
Loading profile data...