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