-
-
Notifications
You must be signed in to change notification settings - Fork 46.6k
/
Copy pathrotational_partition
33 lines (28 loc) · 1.06 KB
/
rotational_partition
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
def rotation_partition_function(moment_of_inertia: float,
temperature: float) -> float:
"""
Calculates the rotational partition
function for linear molecules.
>>> round(rotation_partition_function(1e-46, 300), 4)
5.9275
>>> round(rotation_partition_function(2e-46, 300), 4)
11.855
>>> round(rotation_partition_function(-2e-46, 300), 4)
Traceback (most recent call last):
...
ValueError: Moment of inertia must be positive
>>> round(rotation_partition_function(1e-46, -300), 4)
Traceback (most recent call last):
...
ValueError: Temperature must be positive
"""
if moment_of_inertia <= 0:
raise ValueError("Moment of inertia must be positive")
if temperature <= 0:
raise ValueError("Temperature must be positive")
k_B = 1.380649e-23 # Boltzmann constant
h = 6.62607015e-34 # Planck's constant
return (2 * math.pi * moment_of_inertia * k_B * temperature) / (h ** 2)
if __name__ == "__main__":
import doctest
doctest.testmod(name="rotation_partition_function")