xref: /freebsd/lib/msun/man/lgamma.3 (revision 3a8617a83f16ffc9db4f96e1f0f21af94078e6b1)
13a8617a8SJordan K. Hubbard.\" Copyright (c) 1985, 1991 Regents of the University of California.
23a8617a8SJordan K. Hubbard.\" All rights reserved.
33a8617a8SJordan K. Hubbard.\"
43a8617a8SJordan K. Hubbard.\" Redistribution and use in source and binary forms, with or without
53a8617a8SJordan K. Hubbard.\" modification, are permitted provided that the following conditions
63a8617a8SJordan K. Hubbard.\" are met:
73a8617a8SJordan K. Hubbard.\" 1. Redistributions of source code must retain the above copyright
83a8617a8SJordan K. Hubbard.\"    notice, this list of conditions and the following disclaimer.
93a8617a8SJordan K. Hubbard.\" 2. Redistributions in binary form must reproduce the above copyright
103a8617a8SJordan K. Hubbard.\"    notice, this list of conditions and the following disclaimer in the
113a8617a8SJordan K. Hubbard.\"    documentation and/or other materials provided with the distribution.
123a8617a8SJordan K. Hubbard.\" 3. All advertising materials mentioning features or use of this software
133a8617a8SJordan K. Hubbard.\"    must display the following acknowledgement:
143a8617a8SJordan K. Hubbard.\"	This product includes software developed by the University of
153a8617a8SJordan K. Hubbard.\"	California, Berkeley and its contributors.
163a8617a8SJordan K. Hubbard.\" 4. Neither the name of the University nor the names of its contributors
173a8617a8SJordan K. Hubbard.\"    may be used to endorse or promote products derived from this software
183a8617a8SJordan K. Hubbard.\"    without specific prior written permission.
193a8617a8SJordan K. Hubbard.\"
203a8617a8SJordan K. Hubbard.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
213a8617a8SJordan K. Hubbard.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
223a8617a8SJordan K. Hubbard.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
233a8617a8SJordan K. Hubbard.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
243a8617a8SJordan K. Hubbard.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
253a8617a8SJordan K. Hubbard.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
263a8617a8SJordan K. Hubbard.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
273a8617a8SJordan K. Hubbard.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
283a8617a8SJordan K. Hubbard.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
293a8617a8SJordan K. Hubbard.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
303a8617a8SJordan K. Hubbard.\" SUCH DAMAGE.
313a8617a8SJordan K. Hubbard.\"
323a8617a8SJordan K. Hubbard.\"     from: @(#)lgamma.3	6.6 (Berkeley) 12/3/92
333a8617a8SJordan K. Hubbard.\"	$Id: lgamma.3,v 1.6 1994/01/11 00:46:56 jtc Exp $
343a8617a8SJordan K. Hubbard.\"
353a8617a8SJordan K. Hubbard.Dd December 3, 1992
363a8617a8SJordan K. Hubbard.Dt LGAMMA 3
373a8617a8SJordan K. Hubbard.Os BSD 4.3
383a8617a8SJordan K. Hubbard.Sh NAME
393a8617a8SJordan K. Hubbard.Nm lgamma ,
403a8617a8SJordan K. Hubbard.Nm gamma
413a8617a8SJordan K. Hubbard.Nd log gamma function, gamma function
423a8617a8SJordan K. Hubbard.Sh SYNOPSIS
433a8617a8SJordan K. Hubbard.Fd #include <math.h>
443a8617a8SJordan K. Hubbard.Ft extern int
453a8617a8SJordan K. Hubbard.Fa signgam ;
463a8617a8SJordan K. Hubbard.sp
473a8617a8SJordan K. Hubbard.Ft double
483a8617a8SJordan K. Hubbard.Fn lgamma "double x"
493a8617a8SJordan K. Hubbard.Ft double
503a8617a8SJordan K. Hubbard.Fn gamma "double x"
513a8617a8SJordan K. Hubbard.Sh DESCRIPTION
523a8617a8SJordan K. Hubbard.Fn Lgamma x
533a8617a8SJordan K. Hubbard.if t \{\
543a8617a8SJordan K. Hubbardreturns ln\||\(*G(x)| where
553a8617a8SJordan K. Hubbard.Bd -unfilled -offset indent
563a8617a8SJordan K. Hubbard\(*G(x) = \(is\d\s8\z0\s10\u\u\s8\(if\s10\d t\u\s8x\-1\s10\d e\u\s8\-t\s10\d dt	for x > 0 and
573a8617a8SJordan K. Hubbard.br
583a8617a8SJordan K. Hubbard\(*G(x) = \(*p/(\(*G(1\-x)\|sin(\(*px))	for x < 1.
593a8617a8SJordan K. Hubbard.Ed
603a8617a8SJordan K. Hubbard.\}
613a8617a8SJordan K. Hubbard.if n \
623a8617a8SJordan K. Hubbardreturns ln\||\(*G(x)|.
633a8617a8SJordan K. Hubbard.Pp
643a8617a8SJordan K. HubbardThe external integer
653a8617a8SJordan K. Hubbard.Fa signgam
663a8617a8SJordan K. Hubbardreturns the sign of \(*G(x).
673a8617a8SJordan K. Hubbard.Pp
683a8617a8SJordan K. Hubbard.Fn Gamma x
693a8617a8SJordan K. Hubbardreturns \(*G(x), with no effect on
703a8617a8SJordan K. Hubbard.Fa signgam .
713a8617a8SJordan K. Hubbard.Sh IDIOSYNCRASIES
723a8617a8SJordan K. HubbardDo not use the expression
733a8617a8SJordan K. Hubbard.Dq Li signgam\(**exp(lgamma(x))
743a8617a8SJordan K. Hubbardto compute g := \(*G(x).
753a8617a8SJordan K. HubbardInstead use a program like this (in C):
763a8617a8SJordan K. Hubbard.Bd -literal -offset indent
773a8617a8SJordan K. Hubbardlg = lgamma(x); g = signgam\(**exp(lg);
783a8617a8SJordan K. Hubbard.Ed
793a8617a8SJordan K. Hubbard.Pp
803a8617a8SJordan K. HubbardOnly after
813a8617a8SJordan K. Hubbard.Fn lgamma
823a8617a8SJordan K. Hubbardhas returned can signgam be correct.
833a8617a8SJordan K. Hubbard.Pp
843a8617a8SJordan K. HubbardFor arguments in its range,
853a8617a8SJordan K. Hubbard.Fn gamma
863a8617a8SJordan K. Hubbardis preferred, as for positive arguments
873a8617a8SJordan K. Hubbardit is accurate to within one unit in the last place.
883a8617a8SJordan K. HubbardExponentiation of
893a8617a8SJordan K. Hubbard.Fn lgamma
903a8617a8SJordan K. Hubbardwill lose up to 10 significant bits.
913a8617a8SJordan K. Hubbard.Sh RETURN VALUES
923a8617a8SJordan K. Hubbard.Fn Gamma
933a8617a8SJordan K. Hubbardand
943a8617a8SJordan K. Hubbard.Fn lgamma
953a8617a8SJordan K. Hubbardreturn appropriate values unless an argument is out of range.
963a8617a8SJordan K. HubbardOverflow will occur for sufficiently large positive values, and
973a8617a8SJordan K. Hubbardnon-positive integers.
983a8617a8SJordan K. HubbardOn the
993a8617a8SJordan K. Hubbard.Tn VAX,
1003a8617a8SJordan K. Hubbardthe reserved operator is returned,
1013a8617a8SJordan K. Hubbardand
1023a8617a8SJordan K. Hubbard.Va errno
1033a8617a8SJordan K. Hubbardis set to
1043a8617a8SJordan K. Hubbard.Er ERANGE
1053a8617a8SJordan K. HubbardFor large non-integer negative values,
1063a8617a8SJordan K. Hubbard.Fn gamma
1073a8617a8SJordan K. Hubbardwill underflow.
1083a8617a8SJordan K. Hubbard.Sh SEE ALSO
1093a8617a8SJordan K. Hubbard.Xr math 3 ,
1103a8617a8SJordan K. Hubbard.Xr infnan 3
1113a8617a8SJordan K. Hubbard.Sh HISTORY
1123a8617a8SJordan K. HubbardThe
1133a8617a8SJordan K. Hubbard.Nm lgamma
1143a8617a8SJordan K. Hubbardfunction appeared in
1153a8617a8SJordan K. Hubbard.Bx 4.3 .
1163a8617a8SJordan K. HubbardThe
1173a8617a8SJordan K. Hubbard.Nm gamma
1183a8617a8SJordan K. Hubbardfunction appeared in
1193a8617a8SJordan K. Hubbard.Bx 4.4 .
1203a8617a8SJordan K. HubbardThe name
1213a8617a8SJordan K. Hubbard.Fn gamma
1223a8617a8SJordan K. Hubbardwas originally dedicated to the
1233a8617a8SJordan K. Hubbard.Fn lgamma
1243a8617a8SJordan K. Hubbardfunction, so some old code may no longer be compatible.
125