Opened 10 years ago
Closed 10 years ago
#7291 closed Bugs (fixed)
complex atan is not the best it could be
Reported by: | Owned by: | John Maddock | |
---|---|---|---|
Milestone: | To Be Determined | Component: | math |
Version: | Boost 1.52.0 | Severity: | Problem |
Keywords: | Cc: |
Description
For complex atan, when x and y are non-negative, the following formula is rather foolproof:
atanh(z) = 0.25 * log1p(4*x / pow(|z-1|,2)) + 0.5 * I * atan2(2y, (1-x*x-y*y))
where z = x+I*y. Just handle the few special cases when you get overflow or underflow.
I have implemented a C version at http://people.freebsd.org/~stephen/catrig.c.
Also, email Tom Fairgrieve <tff@…>. He has an unpublished work by Hull, himself, and Tang, very similar to the work they did on the complex arcsine.
Attachments (1)
Change History (5)
comment:1 by , 10 years ago
Component: | None → math |
---|---|
Owner: | set to |
comment:2 by , 10 years ago
by , 10 years ago
Attachment: | atanh-patch added |
---|
comment:3 by , 10 years ago
The patch I just uploaded is a diff to today's svn. It seems to work rather well.
Use this for the imaginary part: 0.5 * atan2(2y, (1-x)*(1+x)-y*y) Replacing 1-x*x by (1-x)(1+x) improves the error quite a bit when x is close to 1.