Average Error: 43.5 → 43.5
Time: 25.8s
Precision: 64
Internal Precision: 1344
\[\Im(\left(\frac{\left(\left(e^{\left(xre + xim i\right)}\right) + \left(e^{\left(-\left(xre + xim i\right)\right)}\right)\right)}{\left(2 + 0 i\right)}\right))\]
\[\Im(\left(\frac{\left(\left(e^{\left(-\left(xre + xim i\right)\right)}\right) + \left(e^{\left(xre + xim i\right)}\right)\right)}{\left(2 + 0 i\right)}\right))\]

Error

Bits error versus xre

Bits error versus xim

Derivation

  1. Initial program 43.5

    \[\Im(\left(\frac{\left(\left(e^{\left(xre + xim i\right)}\right) + \left(e^{\left(-\left(xre + xim i\right)\right)}\right)\right)}{\left(2 + 0 i\right)}\right))\]
  2. Final simplification43.5

    \[\leadsto \Im(\left(\frac{\left(\left(e^{\left(-\left(xre + xim i\right)\right)}\right) + \left(e^{\left(xre + xim i\right)}\right)\right)}{\left(2 + 0 i\right)}\right))\]

Reproduce

herbie shell --seed 2019022 +o rules:numerics
(FPCore (xre xim)
  :name "exp with complex power imaginary part (p55)"
  (im (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0))))

Details

Time bar (total: 22.9s)Debug log

sample929.0ms

Algorithm
halfpoints
Results

simplify11.0ms

Counts
1 → 1
Calls
1 calls:
Slowest
10.0ms
(im (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))

prune37.0ms

Pruning

1 alts after pruning (1 fresh and 0 done)

Merged error: 42.8b

localize162.0ms

Local error

Found 4 expressions with local error:

42.8b
(+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim))))
0.0b
(exp.c (neg.c (complex xre xim)))
0.0b
(exp.c (complex xre xim))
0.0b
(/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0))

rewrite12.0ms

Algorithm
rewrite-expression-head
Rules
+.c-commutative
frac-2neg-c
Counts
4 → 2
Calls
4 calls:
Slowest
5.0ms
(+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim))))
5.0ms
(/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0))
0.0ms
(exp.c (neg.c (complex xre xim)))
0.0ms
(exp.c (complex xre xim))

series1.0ms

Counts
4 → 4
Calls
4 calls:
Slowest
0.0ms
(+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim))))
0.0ms
(exp.c (neg.c (complex xre xim)))
0.0ms
(/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0))
0.0ms
(exp.c (complex xre xim))

simplify54.0ms

Counts
4 → 6
Calls
4 calls:
Slowest
28.0ms
(im (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))
9.0ms
(im (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))
9.0ms
(im (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))
7.0ms
(im (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))

prune27.0ms

Pruning

1 alts after pruning (0 fresh and 1 done)

Merged error: 42.8b

end0.0ms

sample21.6s

Algorithm
halfpoints
Results