Average Error: 0.0 → 0.0
Time: 16.7s
Precision: 64
Internal Precision: 576
\[\Re(\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))\]
\[\Re(\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 0.0

    \[\Re(\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 simplification0.0

    \[\leadsto \Re(\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 2019021 
(FPCore (xre xim)
  :name "exp with complex power real part (p55)"
  (re (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0))))

Details

Time bar (total: 14.8s)Debug log

sample1.0s

Algorithm
halfpoints
Results

simplify24.0ms

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

prune7.0ms

Pruning

1 alts after pruning (1 fresh and 0 done)

Merged error: 0.0b

localize53.0ms

Local error

Found 4 expressions with local error:

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

rewrite24.0ms

Algorithm
rewrite-expression-head
Rules
+.c-commutative
frac-2neg-c
Counts
4 → 2
Calls
4 calls:
Slowest
3.0ms
(+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim))))
2.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))
0.0ms
(exp.c (neg.c (complex xre xim)))

series0.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 (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 (neg.c (complex xre xim)))

simplify22.0ms

Counts
4 → 6
Calls
4 calls:
Slowest
8.0ms
(re (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))
5.0ms
(re (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))
5.0ms
(re (/.c (+.c (exp.c (complex xre xim)) (exp.c (neg.c (complex xre xim)))) (complex 2 0)))
4.0ms
(re (/.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: 0.0b

end0.0ms

sample13.6s

Algorithm
halfpoints
Results