Python program to calculate logarithmic gamma of a given number

WBOY
Release: 2023-09-04 22:05:05
forward
768 people have browsed it

Python program to calculate logarithmic gamma of a given number

In mathematics, the gamma function is considered to be the expansion of the factorial of any given number. However, since factorial is defined only for real numbers, the gamma function is beyond the scope of defining factorial for all complex numbers except negative integers. It is represented by -

Γ(x) = (x-1)!
Copy after login

Logarithmic Gamma Function appears because the gamma function only grows rapidly at larger numbers, so applying the logarithm to gamma will slow it down a lot. It is also known as the natural logarithm gamma of a given number.

log(Γ(x)) = log((x-1)!)
Copy after login

In the Python programming language, like other programming languages, the logarithmic gamma function is calculated using the math.lgamma() function. However, we will also look at a few other ways to calculate the log gamma of a number in this article.

Input and output scenarios

Let's look at some input and output scenarios to find the log-gamma function using the math.lgamma() method.

Assume that the input of the logarithmic gamma function is a positive integer -

Input: 12
Result: 17.502307845873887
Copy after login

Assume that the input of the logarithmic gamma function is a negative integer -

Input: -12
Result: “ValueError: math domain error”
Copy after login

Assume that the input to the log gamma function is zero -

Input: 0
Result: “ValueError: math domain error”
Copy after login

Assume that the input to the log gamma function is a negative decimal value close to zero -

Input: -0.2
Result: 1.761497590833938
Copy after login

A domain error occurs when using the lgamma() method because the function is defined for all complex numbers minus negative "integers". Let's look at various ways to find the log gamma of a given number.

Usemath.lgamma()Function

The lgamma() method is defined in the math library and returns the natural logarithm gamma value of a given number. The syntax of this method is -

math.lgamma(x)
Copy after login

where x is any complex number except negative integers.

Example

The Python example of using the math.lgamma() function to find log gamma is as follows -

# import math library
import math

#log gamma of positive integer
x1 = 10
print(math.lgamma(x1))

#log gamma of negative complex number
x2 = -1.2
print(math.lgamma(x2))

#log gamma of a positive complex number
x3 = 3.4
print(math.lgamma(x3))
Copy after login

Output

The output of the above python code is -

12.801827480081467
1.5791760340399836
1.0923280598027416
Copy after login

Using math.gamma() and math.log() functions

In another approach, the logarithm of a number can be found by first finding the gamma of the number using the math.gamma() function, and then applying the logarithm to the gamma value using gamma. b>math.log() function. Here, we just break the lgamma() function into steps.

Example

The python implementation of the above process is as follows -

# import math library
import math

#log gamma of positive integer
x1 = math.gamma(10)
print(math.log(x1))

#log gamma of negative complex number
x2 = math.gamma(-1.2)
print(math.log(x2))

#log gamma of a positive complex number
x3 = math.gamma(3.4)
print(math.log(x3))
Copy after login

Output

The output obtained is as follows -

12.801827480081469
1.5791760340399839
1.0923280598027414
Copy after login

By applying logarithms to the factorial of a number

An easier way is to find the factorial of a given number, since the gamma function is defined as the factorial of a complex number, and compute the factorial by applying the logarithm to it using the math.log() method.

Example

In this Python example, we use factorial and the math.log() method to find the logarithmic gamma of a number. The only disadvantage of using this method is that it only works with positive integers.

# import math library
import math

def factorial(n):
   if n == 1:
      return 1
   else:
      return n*factorial(n-1)
	
#log gamma of positive integer
x1 = 10
y1 = factorial(x1-1)
print(math.log(y1))

x2 = 3
y2 = factorial(x2-1)
print(math.log(y2))

#log gamma of a positive complex number
x3 = 3.4
y3 = factorial(x3-1)
print(math.log(y3))
Copy after login

Output

The output is -

12.801827480081469
0.6931471805599453
RecursionError: maximum recursion depth exceeded in comparison
Copy after login

The above is the detailed content of Python program to calculate logarithmic gamma of a given number. For more information, please follow other related articles on the PHP Chinese website!

source:tutorialspoint.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!