xref: /openbsd-src/lib/libm/src/s_clogl.c (revision 2f2c00629eff6a304ebffb255fc56f4fa7a1833b)
1*2f2c0062Sguenther /*	$OpenBSD: s_clogl.c,v 1.3 2016/09/12 19:47:02 guenther Exp $	*/
2de3697aaSmartynas 
3de3697aaSmartynas /*
4de3697aaSmartynas  * Copyright (c) 2008 Stephen L. Moshier <steve@moshier.net>
5de3697aaSmartynas  *
6de3697aaSmartynas  * Permission to use, copy, modify, and distribute this software for any
7de3697aaSmartynas  * purpose with or without fee is hereby granted, provided that the above
8de3697aaSmartynas  * copyright notice and this permission notice appear in all copies.
9de3697aaSmartynas  *
10de3697aaSmartynas  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11de3697aaSmartynas  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12de3697aaSmartynas  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13de3697aaSmartynas  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14de3697aaSmartynas  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15de3697aaSmartynas  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16de3697aaSmartynas  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17de3697aaSmartynas  */
18de3697aaSmartynas 
19de3697aaSmartynas /*							clogl.c
20de3697aaSmartynas  *
21de3697aaSmartynas  *	Complex natural logarithm
22de3697aaSmartynas  *
23de3697aaSmartynas  *
24de3697aaSmartynas  *
25de3697aaSmartynas  * SYNOPSIS:
26de3697aaSmartynas  *
27de3697aaSmartynas  * long double complex clogl();
28de3697aaSmartynas  * long double complex z, w;
29de3697aaSmartynas  *
30de3697aaSmartynas  * w = clogl( z );
31de3697aaSmartynas  *
32de3697aaSmartynas  *
33de3697aaSmartynas  *
34de3697aaSmartynas  * DESCRIPTION:
35de3697aaSmartynas  *
36de3697aaSmartynas  * Returns complex logarithm to the base e (2.718...) of
37de3697aaSmartynas  * the complex argument x.
38de3697aaSmartynas  *
39de3697aaSmartynas  * If z = x + iy, r = sqrt( x**2 + y**2 ),
40de3697aaSmartynas  * then
41de3697aaSmartynas  *       w = log(r) + i arctan(y/x).
42de3697aaSmartynas  *
43de3697aaSmartynas  * The arctangent ranges from -PI to +PI.
44de3697aaSmartynas  *
45de3697aaSmartynas  *
46de3697aaSmartynas  * ACCURACY:
47de3697aaSmartynas  *
48de3697aaSmartynas  *                      Relative error:
49de3697aaSmartynas  * arithmetic   domain     # trials      peak         rms
50de3697aaSmartynas  *    DEC       -10,+10      7000       8.5e-17     1.9e-17
51de3697aaSmartynas  *    IEEE      -10,+10     30000       5.0e-15     1.1e-16
52de3697aaSmartynas  *
53de3697aaSmartynas  * Larger relative error can be observed for z near 1 +i0.
54de3697aaSmartynas  * In IEEE arithmetic the peak absolute error is 5.2e-16, rms
55de3697aaSmartynas  * absolute error 1.0e-16.
56de3697aaSmartynas  */
57de3697aaSmartynas 
58de3697aaSmartynas #include <complex.h>
59de3697aaSmartynas #include <math.h>
60de3697aaSmartynas 
61de3697aaSmartynas long double complex
clogl(long double complex z)62de3697aaSmartynas clogl(long double complex z)
63de3697aaSmartynas {
64de3697aaSmartynas 	long double complex w;
65de3697aaSmartynas 	long double p, rr;
66de3697aaSmartynas 
67de3697aaSmartynas 	/*rr = sqrt(z->r * z->r  +  z->i * z->i);*/
68de3697aaSmartynas 	p = cabsl(z);
69de3697aaSmartynas 	p = logl(p);
70c18f5b07Smartynas 	rr = atan2l(cimagl(z), creall(z));
71de3697aaSmartynas 	w = p + rr * I;
72de3697aaSmartynas 	return (w);
73de3697aaSmartynas }
74*2f2c0062Sguenther DEF_STD(clogl);
75