From: "Richard B. Kreckel" <kreckel-HEL5OUoDxoc@public.gmane.org>
To: mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org
Cc: Andries Brouwer <Andries.Brouwer-rh8NL+sEX9E@public.gmane.org>,
linux-man-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
Andreas Enge <andreas.enge-MZpvjPyXg2s@public.gmane.org>,
Bill Allombert
<Bill.Allombert-AE+LCD0i0auq1rftRos53FaPQRlvutdw@public.gmane.org>,
Karim Belabas
<Karim.Belabas-AE+LCD0i0auq1rftRos53FaPQRlvutdw@public.gmane.org>
Subject: Re: Wrong formulae for complex elementary functions
Date: Fri, 05 Aug 2011 23:34:54 +0200 [thread overview]
Message-ID: <4E3C61FE.1010107@ginac.de> (raw)
In-Reply-To: <AANLkTinAUyVTdjxY9KVgnOerWxhXtnvmHeTQ-Gb0-TxC-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
Hi everybody,
On 11/27/2010 08:37 AM, Michael Kerrisk wrote:
> Hi Andries,
>
> Since you are the mathematician, can you comment?
>
> Thanks,
>
> Michael
>
> On Fri, Nov 26, 2010 at 9:57 AM, Richard B. Kreckel<kreckel-HEL5OUoDxoc@public.gmane.org> wrote:
>> Hi!
>>
>> The man pages for cacos, cacosf, cacosl, catan, catanf, catanl, cacosh,
>> cacoshf, cacoshl, catanh, catanhf, and catanhl contain wrong maths.
>>
>> cacos, cacosf, cacosl:
>> The formula given in the man page
>> cacos(z) = -i clog(z + csqrt(z * z - 1))
>> gives wrong results in second and fourth quadrant of complex plain.
>> The formula
>> cacos(z) = -i clog(z + I*csqrt(1 - z * z))
>> gives correct results.
>>
>> catan, catanf, catanl:
>> The formula given in the man page
>> catan(z) = 1 / 2i clog((1 + iz) / (1 - iz))
>> gives wrong results on the negative imaginary axis beginning at -I
>> (along one of the two branch cuts). Besides, the formula is written
>> in an ambiguous way.
>> The formula
>> catan(z) = (clog(1 + iz) - clog(1 - iz)) / 2i
>> gives correct results.
>>
>> cacosh, cacoshf, cacoshl:
>> The formula given in the man page
>> cacosh(z) = (0.5) * clog((1 + z) / (1 - z))
>> gives wrong results everywhere in the complex plain. (The formula
>> seems to be copied from the one for catanh, where it is sometimes
>> correct.)
>> The formula
>> cacosh(z) = 2 * clog(csqrt((z + 1)/2) + csqrt((z - 1)/2))
>> gives correct results.
>>
>> catanh, catanhf, catanhl:
>> The formula given in the man page
>> catanh(z) = 0.5 * clog((1 + z) / (1 - z))
>> gives wrong results on the positive real axis beginning at 1 (along
>> one of the two branch cuts).
>> The formula
>> catanh(z) = 0.5 * (clog(1 + z) - clog(1 - z))
>> gives correct results.
>>
>> I've also checked casin, casinf, casinl, casinh, casinhf, and casinhl and
>> the formulae given there
>> casin(z) = -i clog(iz + csqrt(1 - z * z))
>> casinh(z) = clog(z + csqrt(z * z + 1))
>> are actually correct.
>>
>> I suspect that some of these errors are due to somebody trying to "simplify"
>> these formulae. Since this can ruin the behavior, I recommend to add a
>> comment to the upstream sources that warns against attempt of
>> simplification.
>>
>> For the sake of reference, I am looking at manpages-dev 3.25-1 on
>> Debian/squeeze.
>>
>> Bye!
>> -richy.
>> --
>> Richard B. Kreckel
>> <http://www.ginac.de/~kreckel/>
This doesn't have seem to have been fixed in the Linux man pages, does it?
May I suggest a non-mathematical approach to moving forward?
Just write a little C program and compare the complex results of
a) the library implementation of catan, cacos, etc.,
b) the formula written in the man page, and
c) the formula I proposed above.
If you include a couple of values from all four quadrants, you'll see
that my formula always agrees with the implementation while the one from
the man page doesn't.
Is there anything else I can do to convince you that this should be
fixed? If yes, pretty please, let me know! I would really appreciate
getting this fixed.
Best wishes
-richy.
--
Richard B. Kreckel
<http://www.ginac.de/~kreckel/>
--
To unsubscribe from this list: send the line "unsubscribe linux-man" in
the body of a message to majordomo-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
next prev parent reply other threads:[~2011-08-05 21:34 UTC|newest]
Thread overview: 11+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-11-26 8:57 Wrong formulae for complex elementary functions Richard B. Kreckel
[not found] ` <4CEF7677.30500-HEL5OUoDxoc@public.gmane.org>
2010-11-27 7:37 ` Michael Kerrisk
[not found] ` <AANLkTinAUyVTdjxY9KVgnOerWxhXtnvmHeTQ-Gb0-TxC-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2011-08-05 21:34 ` Richard B. Kreckel [this message]
[not found] ` <4E3C61FE.1010107-HEL5OUoDxoc@public.gmane.org>
2011-09-15 4:31 ` Michael Kerrisk
[not found] ` <CAKgNAkjamtuK95ouh6+zsCS1dHiZO0-1q72GpN0CSaFk9XxWqg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2011-09-15 8:34 ` Richard B. Kreckel
2011-09-15 18:38 ` Michael Kerrisk
[not found] ` <CAKgNAkiv7-FL95p2D_80EaRTxhbwDOTun7N_uSsPr2e71Cz8EA-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2011-09-15 21:42 ` Richard B. Kreckel
[not found] ` <4E727152.2060503-HEL5OUoDxoc@public.gmane.org>
2011-09-16 6:05 ` Michael Kerrisk
[not found] ` <CAKgNAkgHrLgk+QBs0jnWXavj5PLBPhaLO=33tgQxAwTUyFhzwg-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2011-09-16 9:45 ` D. Barbier
2011-09-15 16:24 ` Andries E. Brouwer
2011-09-15 18:36 ` Michael Kerrisk
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4E3C61FE.1010107@ginac.de \
--to=kreckel-hel5ouodxoc@public.gmane.org \
--cc=Andries.Brouwer-rh8NL+sEX9E@public.gmane.org \
--cc=Bill.Allombert-AE+LCD0i0auq1rftRos53FaPQRlvutdw@public.gmane.org \
--cc=Karim.Belabas-AE+LCD0i0auq1rftRos53FaPQRlvutdw@public.gmane.org \
--cc=andreas.enge-MZpvjPyXg2s@public.gmane.org \
--cc=linux-man-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
--cc=mtk.manpages-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox