mirror of
https://hub.njuu.cf/TheAlgorithms/Python.git
synced 2023-10-11 13:06:12 +08:00
Updated file
This commit is contained in:
parent
974e0a6e95
commit
1d4fc814fa
83
maths/gamma_recursive.py
Normal file
83
maths/gamma_recursive.py
Normal file
@ -0,0 +1,83 @@
|
||||
"""
|
||||
Gamma function is a very useful tool in physics.
|
||||
It helps calculating complex integral in a convenient way.
|
||||
for more info: https://en.wikipedia.org/wiki/Gamma_function
|
||||
"""
|
||||
|
||||
# Importing packages
|
||||
from math import sqrt, pi
|
||||
from re import match
|
||||
from typing import Union
|
||||
|
||||
|
||||
def gamma(num : Union[int, float]) -> Union[int, float]:
|
||||
"""
|
||||
Calculates the value of Gamma function of num
|
||||
where num is either an integer (1,2,3..) or a half-integer (0.5,1.5,2.5...).
|
||||
Implemented using recursion
|
||||
Examples:
|
||||
>>> Gamma of: 0.5
|
||||
√π
|
||||
>>> Gamma of: 2
|
||||
1
|
||||
>>> Gamma of: 3.5
|
||||
1.875√π
|
||||
"""
|
||||
if num == 1:
|
||||
return 1
|
||||
elif num == 0.5:
|
||||
return sqrt(pi)
|
||||
elif num > 1:
|
||||
return (num - 1) * gamma(num - 1)
|
||||
# Error
|
||||
return -2
|
||||
|
||||
|
||||
def test_gamma() -> None:
|
||||
"""
|
||||
>>> test_gamma()
|
||||
"""
|
||||
assert sqrt(pi) == gamma(0.5)
|
||||
assert 1 == gamma(1)
|
||||
assert 1 == gamma(2)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
# Initialize boolean
|
||||
number = True
|
||||
# Get input from user
|
||||
input_ = input("Gamma of: ")
|
||||
# Ensure valid input
|
||||
try:
|
||||
# Ensure input matches half-integer (float) pattern
|
||||
if match(r"^[0-9]*\.5$", input_):
|
||||
# Convert string to float
|
||||
num = float(input_)
|
||||
# Ensure input matches an integer pattern
|
||||
elif match(r"^[1-9][0-9]*$", input_):
|
||||
# Convert string to int
|
||||
num = int(input_)
|
||||
# Input is not a valid number
|
||||
else:
|
||||
# raise an error
|
||||
raise ValueError
|
||||
# Ensure print an error message
|
||||
except ValueError:
|
||||
print("Error: Input must be an integer or an half-integer!")
|
||||
number = False
|
||||
finally:
|
||||
# Ensure input is a valid number
|
||||
if number:
|
||||
print(f"\u0393({num}) = ", end="")
|
||||
# Ensure input is an integer
|
||||
if isinstance(gamma(num), int):
|
||||
# Print result
|
||||
print(gamma(num))
|
||||
# Otherwise print results with √π (gamma of 0.5 is √π)
|
||||
# Therefore all results will be a number times √π
|
||||
else:
|
||||
results = f"{gamma(num) / sqrt(pi):.4f}"
|
||||
results = results.rstrip("0").rstrip(".")
|
||||
if results == "1":
|
||||
results = ""
|
||||
print(results + "\u221A\u03c0")
|
Loading…
Reference in New Issue
Block a user