-
Notifications
You must be signed in to change notification settings - Fork 15
/
main.py
95 lines (75 loc) · 3.39 KB
/
main.py
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
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
"""
This is the Hartree-Fock SCF Assignmentthat is for the class assignment for
Modern Programming in Data Analytics
It is intended to give students a basic exposure to the following concepts
1. Working with novel libraries
2. Converting math to python programming
3. Basic exposure to using NumPy and SciPy
4. Proper documentation of code and unit testing
The instructions for the assignement come in the Readme from the repository
at:
"""
from pyscf import gto # PySCF is a quantum chemistry python module
import SCF
def main():
"""
The main function call, meant to gather input and invoke the
Hartree Fock Self Consistent Field Procedure
Output:
The total Hartee-Fock Energy of the molecule
"""
# Input Data
mol_h2o = gto.M(unit="Bohr",
atom="O 0.000000000000 -0.143225816552 0.000000000000;"
+ "H 1.638036840407 1.136548822547 -0.000000000000;"
+ "H -1.638036840407 1.136548822547 -0.000000000000",
basis='STO-3g')
mol_h2o.build()
# Convergence Criteria
E_conv_threshold = 1.0E-10
D_conv_threshold = 1.0E-8
max_iterations = 1000
# get the integrals
Suv = mol_h2o.intor('int1e_ovlp') # Overlap Integrals
Tuv = mol_h2o.intor('int1e_kin') # Kinetic Energy 1 electron integrals
Vuv = mol_h2o.intor('int1e_nuc') # Nuclear Repulsion 1 electron integrals
eri = mol_h2o.intor("int2e") # Electron Repulsion 2 electron integrals
"""
Main SCF Procedure
Each step is outlined in the Github Repo Readme
Your job will be to fill in the stubbed functions in SCF.py
Step 1. Calculate the Electron Nuclear Repulsion Energy
Step 2. Calculate the Initial Hcore Matrix
Step 3. Calculate the Inital Density Matrix
Step 4. Start the SCF Procedure
Step 4a. Calculate the Fock Matrix
Step 4b. Solve Eigenvalues and Eigenvectors of Roothan Equations
Step 4c. Calculate the Total Energy of the Current Iteration
Step 4d. Caluate the new Density Matrix
Step 4e. Calulate the Energy Difference and RMS Difference of Density
Step 4f. Check for Convergence, if Converged, Exit
Step 4g. If not Converged, update Density Matrix and Energy and do
another iteration
Step 5. Print out Final Total Energy for User
"""
Enuc = SCF.calc_nuclear_repulsion_energy(mol_h2o)
Huv = SCF.calc_hcore_matrix(Tuv, Vuv)
Duv = SCF.calc_initial_density(mol_h2o)
Etot = 0.0
for it in range(max_iterations):
Fuv = SCF.calc_fock_matrix(mol_h2o, Huv, eri, Duv)
mo_e, mo_c = SCF.solve_Roothan_equations(Fuv, Suv)
Etot_new = SCF.calc_tot_energy(Fuv, Huv, Duv, Enuc)
Duv_new = SCF.form_density_matrix(mol_h2o, mo_c)
dEtot = abs(Etot_new - Etot)
dDuv = (((Duv_new - Duv)**2).sum())**(1.0/2.0)
if dEtot < E_conv_threshold and dDuv < D_conv_threshold:
print("Final Energy = {:.10f}".format(Etot_new))
break
print("Etot = {:.10f} dEtot = {:.10f} dDuv = {:.10f}".format(Etot_new,
dEtot,
dDuv))
Duv = Duv_new.copy()
Etot = Etot_new
if __name__ == "__main__":
main()