-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathBeH2_insert.py
116 lines (102 loc) · 4.11 KB
/
BeH2_insert.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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
from energycalculator import *
import matplotlib.pyplot as plt
import matplotlib
matplotlib.use('Agg')
class EnergyCalculator(EnergyCalculatorBase):
def get_geometry(self, dist, string=False):
y = lambda x: 2.54 - 0.46*x
if string:
geometry = "Be 0 0 0;"
geometry += "H " + str(y(dist)) + " 0 0;"
geometry += "H " + str(-y(dist)) + " 0 0;"
return geometry
else:
geometry = []
geometry.append(("Be", [ 0., 0, 0.]))
geometry.append(("H" , [ y(dist), 0., 0.]))
geometry.append(("H" , [-y(dist), 0., 0.]))
return geometry
ecalc = EnergyCalculator()
backend = BasicAer.get_backend("statevector_simulator")
#backend = Aer.get_backend("qasm_simulator")
res=15
dists = np.linspace(0, 4., res)
fci_energies_sto3g = []
fci_energies_ccpvdz = []
ccsd_energies_sto3g = []
ccsd_energies_ccpvdz = []
quccsd_energies_sto3g = []
#quccsd_energies_ccpvdz = []
### 1) Hartree Fock-energies
i = 0
diagvalues = np.zeros((len(dists), 14))
for dist in dists:
diagvalues[i,:] = ecalc.get_onebodyintegrals_HF(dist)
i += 1
plt.figure(figsize=(20,10), dpi=400)
plt.plot(dists, diagvalues, 'x-')
plt.savefig('BeH2_HF_insert.png')
#to reduce the number of qubits used, we freeze the core and remove two unoccupied orbitals
freeze_list = [0]
remove_list = []
#remove_list = [-4, -3]
### 2) calculate energies
for dist in dists:
print("interatomic distance=", dist)
print("fci energy", end=" ")
energy = ecalc.get_fci_energy(dist, basis = 'sto-3g')
fci_energies_sto3g.append(energy)
print("sto-3g=", energy, end=" ")
energy = ecalc.get_fci_energy(dist, basis = 'ccpvdz')
fci_energies_ccpvdz.append(energy)
print("ccpvdz=", energy)
#energy = ecalc.get_fci_energy(dist, basis = 'ccpvtz')
#fci_energies_ccpvtz.append(energy)
#print("ccpvtz=", energy)
#print("exact energy", end=" ")
#energy = ecalc.get_exact_energy(dist, backend)#, freeze_list = freeze_list, remove_list = remove_list)
#exact_energies.append(energy)
#print(energy)
print("quccsd energy", end=" ")
energy = ecalc.get_quccsd_energy(dist, backend, freeze_list = freeze_list, remove_list = remove_list, basis='sto-3g')
quccsd_energies_sto3g.append(energy)
print("sto-3g=", energy, end=" ")
#energy = ecalc.get_quccsd_energy(dist, backend, freeze_list = freeze_list, remove_list = remove_list, basis= 'ccpvdz')
#quccsd_energies_ccpvdz.append(energy)
#print("ccpvdz=", energy)
print()
print("ccsd energy", end=" ")
energy = ecalc.get_ccsd_energy(dist, basis = 'sto-3g')
ccsd_energies_sto3g.append(energy)
print("sto-3g=", energy, end=" ")
energy = ecalc.get_ccsd_energy(dist, basis = 'cc-pVDZ')
ccsd_energies_ccpvdz.append(energy)
print("ccpvdz=", energy)
print()
plt.clf()
plt.plot(dists, fci_energies_sto3g, 'x-', label="FCI sto-3g")
plt.plot(dists, fci_energies_ccpvdz, 'o:', label="FCI cc-pVDZ")
#plt.plot(dists, fci_energies_ccpvtz, '<-', label="FCI cc-pVTZ")
#plt.plot(dists, exact_energies, 'o-', label="eigensolver")
plt.plot(dists, quccsd_energies_sto3g, '<-',label="q-UCCSD sto-3g")
#plt.plot(dists, quccsd_energies_ccpvdz, 's:',label="q-UCCSD cc-pVDZ")
plt.plot(dists, ccsd_energies_sto3g, '*-',label="CCSD sto-3g")
plt.plot(dists, ccsd_energies_ccpvdz, '1:',label="CCSD cc-pVDZ")
plt.xlabel('Interatomic distance (Angstrom)')
plt.ylabel('Energy')
plt.legend()
plt.savefig('BeH2_insert.png')
plt.clf()
plt.plot(dists, np.array(fci_energies_sto3g)-np.array(ccsd_energies_sto3g), 's-',label="CCSD")
plt.plot(dists, np.array(fci_energies_sto3g)-np.array(quccsd_energies_sto3g), 'x-', label="quccsd")
plt.xlabel('Interatomic distance (Angstrom)')
plt.ylabel('Energy distance to FCI solution')
plt.legend()
plt.savefig('BeH2diff_sto3g.png')
plt.clf()
plt.plot(dists, np.array(fci_energies_ccpvdz)-np.array(ccsd_energies_ccpvdz), 's-',label="CCSD")
#plt.plot(dists, np.array(fci_energies_ccpvdz)-np.array(quccsd_energies_ccpvdz), 'x-', label="quccsd")
plt.xlabel('Interatomic distance (Angstrom)')
plt.ylabel('Energy distance to FCI solution')
plt.legend()
plt.savefig('BeH2diff_ccpvdz.png')