Skip to content

Commit b3f481b

Browse files
committed
Merge branch 'dev-stable' of https://github.com/QuantumPackage/qp2 into dev-stable
2 parents fe675fa + f6661b6 commit b3f481b

File tree

2 files changed

+129
-39
lines changed

2 files changed

+129
-39
lines changed

src/determinants/ref_bitmask.irp.f

Lines changed: 125 additions & 39 deletions
Original file line numberDiff line numberDiff line change
@@ -1,84 +1,170 @@
1-
BEGIN_PROVIDER [ double precision, ref_bitmask_energy ]
2-
&BEGIN_PROVIDER [ double precision, ref_bitmask_one_e_energy ]
3-
&BEGIN_PROVIDER [ double precision, ref_bitmask_kinetic_energy ]
4-
&BEGIN_PROVIDER [ double precision, ref_bitmask_n_e_energy ]
5-
&BEGIN_PROVIDER [ double precision, ref_bitmask_two_e_energy ]
6-
&BEGIN_PROVIDER [ double precision, ref_bitmask_energy_ab ]
7-
&BEGIN_PROVIDER [ double precision, ref_bitmask_energy_bb ]
8-
&BEGIN_PROVIDER [ double precision, ref_bitmask_energy_aa ]
1+
BEGIN_PROVIDER [ double precision, ref_bitmask_one_e_energy ]
92

103
use bitmasks
114
implicit none
125
BEGIN_DOC
13-
! Energy of the reference bitmask used in Slater rules
6+
! One-electron energy of the reference bitmask used in Slater rules
147
END_DOC
158

169
integer :: occ(N_int*bit_kind_size,2)
17-
integer :: i,j
10+
integer :: i
1811

1912
call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
2013
call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)
2114

2215

23-
ref_bitmask_energy = 0.d0
2416
ref_bitmask_one_e_energy = 0.d0
17+
18+
do i = 1, elec_beta_num
19+
ref_bitmask_one_e_energy += mo_one_e_integrals(occ(i,1),occ(i,1)) + mo_one_e_integrals(occ(i,2),occ(i,2))
20+
enddo
21+
22+
do i = elec_beta_num+1,elec_alpha_num
23+
ref_bitmask_one_e_energy += mo_one_e_integrals(occ(i,1),occ(i,1))
24+
enddo
25+
26+
END_PROVIDER
27+
28+
BEGIN_PROVIDER [ double precision, ref_bitmask_kinetic_energy ]
29+
30+
use bitmasks
31+
implicit none
32+
BEGIN_DOC
33+
! Kinetic energy of the reference bitmask used in Slater rules
34+
END_DOC
35+
36+
integer :: occ(N_int*bit_kind_size,2)
37+
integer :: i
38+
39+
call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
40+
call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)
41+
42+
2543
ref_bitmask_kinetic_energy = 0.d0
26-
ref_bitmask_n_e_energy = 0.d0
27-
ref_bitmask_two_e_energy = 0.d0
2844

2945
do i = 1, elec_beta_num
30-
ref_bitmask_energy += mo_one_e_integrals(occ(i,1),occ(i,1)) + mo_one_e_integrals(occ(i,2),occ(i,2))
3146
ref_bitmask_kinetic_energy += mo_kinetic_integrals(occ(i,1),occ(i,1)) + mo_kinetic_integrals(occ(i,2),occ(i,2))
47+
enddo
48+
49+
do i = elec_beta_num+1,elec_alpha_num
50+
ref_bitmask_kinetic_energy += mo_kinetic_integrals(occ(i,1),occ(i,1))
51+
enddo
52+
53+
END_PROVIDER
54+
55+
BEGIN_PROVIDER [ double precision, ref_bitmask_n_e_energy ]
56+
57+
use bitmasks
58+
implicit none
59+
BEGIN_DOC
60+
! Nucleus-electron energy of the reference bitmask used in Slater rules
61+
END_DOC
62+
63+
integer :: occ(N_int*bit_kind_size,2)
64+
integer :: i
65+
66+
call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
67+
call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)
68+
69+
70+
ref_bitmask_n_e_energy = 0.d0
71+
72+
do i = 1, elec_beta_num
3273
ref_bitmask_n_e_energy += mo_integrals_n_e(occ(i,1),occ(i,1)) + mo_integrals_n_e(occ(i,2),occ(i,2))
74+
enddo
75+
76+
do i = elec_beta_num+1,elec_alpha_num
77+
ref_bitmask_n_e_energy += mo_integrals_n_e(occ(i,1),occ(i,1))
78+
enddo
79+
80+
END_PROVIDER
81+
82+
BEGIN_PROVIDER [ double precision, ref_bitmask_two_e_energy ]
83+
84+
use bitmasks
85+
implicit none
86+
BEGIN_DOC
87+
! Energy of the reference bitmask used in Slater rules
88+
END_DOC
89+
90+
integer :: occ(N_int*bit_kind_size,2)
91+
integer :: i,j
92+
93+
call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
94+
call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)
95+
96+
ref_bitmask_two_e_energy = 0.d0
97+
98+
do i = 1, elec_beta_num
3399
do j = i+1, elec_alpha_num
34100
ref_bitmask_two_e_energy += mo_two_e_integrals_jj_anti(occ(j,1),occ(i,1))
35-
ref_bitmask_energy += mo_two_e_integrals_jj_anti(occ(j,1),occ(i,1))
36101
enddo
37102
do j= 1, elec_alpha_num
38103
ref_bitmask_two_e_energy += mo_two_e_integrals_jj(occ(j,1),occ(i,2))
39-
ref_bitmask_energy += mo_two_e_integrals_jj(occ(j,1),occ(i,2))
40104
enddo
41105
do j = i+1, elec_beta_num
42106
ref_bitmask_two_e_energy += mo_two_e_integrals_jj_anti(occ(j,2),occ(i,2))
43-
ref_bitmask_energy += mo_two_e_integrals_jj_anti(occ(j,2),occ(i,2))
44107
enddo
45108
enddo
46109

47110
do i = elec_beta_num+1,elec_alpha_num
48-
ref_bitmask_energy += mo_one_e_integrals(occ(i,1),occ(i,1))
49-
ref_bitmask_kinetic_energy += mo_kinetic_integrals(occ(i,1),occ(i,1))
50-
ref_bitmask_n_e_energy += mo_integrals_n_e(occ(i,1),occ(i,1))
51111
do j = i+1, elec_alpha_num
52112
ref_bitmask_two_e_energy += mo_two_e_integrals_jj_anti(occ(j,1),occ(i,1))
53-
ref_bitmask_energy += mo_two_e_integrals_jj_anti(occ(j,1),occ(i,1))
54113
enddo
55114
enddo
56115

57-
ref_bitmask_one_e_energy = ref_bitmask_kinetic_energy + ref_bitmask_n_e_energy
116+
END_PROVIDER
58117

59-
ref_bitmask_energy_ab = 0.d0
60-
do i = 1, elec_alpha_num
61-
do j = 1, elec_beta_num
62-
ref_bitmask_energy_ab += mo_two_e_integrals_jj(occ(i,1),occ(j,2))
118+
BEGIN_PROVIDER [ double precision, ref_bitmask_energy_ab ]
119+
&BEGIN_PROVIDER [ double precision, ref_bitmask_energy_bb ]
120+
&BEGIN_PROVIDER [ double precision, ref_bitmask_energy_aa ]
121+
122+
use bitmasks
123+
implicit none
124+
BEGIN_DOC
125+
! Energy of the reference bitmask used in Slater rules
126+
END_DOC
127+
128+
integer :: occ(N_int*bit_kind_size,2)
129+
integer :: i,j
130+
131+
call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
132+
call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)
133+
134+
ref_bitmask_energy_ab = 0.d0
135+
do i = 1, elec_alpha_num
136+
do j = 1, elec_beta_num
137+
ref_bitmask_energy_ab += mo_two_e_integrals_jj(occ(i,1),occ(j,2))
138+
enddo
63139
enddo
64-
enddo
65140

66-
ref_bitmask_energy_aa = 0.d0
67-
do i = 1, elec_alpha_num
68-
do j = 1, elec_alpha_num
69-
ref_bitmask_energy_aa += mo_two_e_integrals_jj_anti(occ(i,1),occ(j,1))
141+
ref_bitmask_energy_aa = 0.d0
142+
do i = 1, elec_alpha_num
143+
do j = 1, elec_alpha_num
144+
ref_bitmask_energy_aa += mo_two_e_integrals_jj_anti(occ(i,1),occ(j,1))
145+
enddo
70146
enddo
71-
enddo
72-
ref_bitmask_energy_aa = ref_bitmask_energy_aa * 0.5d0
147+
ref_bitmask_energy_aa = ref_bitmask_energy_aa * 0.5d0
73148

74-
ref_bitmask_energy_bb = 0.d0
75-
do i = 1, elec_beta_num
76-
do j = 1, elec_beta_num
77-
ref_bitmask_energy_bb += mo_two_e_integrals_jj_anti(occ(i,2),occ(j,2))
149+
ref_bitmask_energy_bb = 0.d0
150+
do i = 1, elec_beta_num
151+
do j = 1, elec_beta_num
152+
ref_bitmask_energy_bb += mo_two_e_integrals_jj_anti(occ(i,2),occ(j,2))
153+
enddo
78154
enddo
79-
enddo
80-
ref_bitmask_energy_bb = ref_bitmask_energy_bb * 0.5d0
155+
ref_bitmask_energy_bb = ref_bitmask_energy_bb * 0.5d0
156+
157+
END_PROVIDER
158+
159+
BEGIN_PROVIDER [ double precision, ref_bitmask_energy ]
160+
161+
use bitmasks
162+
implicit none
163+
BEGIN_DOC
164+
! Energy of the reference bitmask used in Slater rules
165+
END_DOC
81166

167+
ref_bitmask_energy = ref_bitmask_one_e_energy + ref_bitmask_two_e_energy
82168

83169

84170
END_PROVIDER

src/trexio/import_trexio_integrals.irp.f

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -165,6 +165,7 @@ subroutine run(f)
165165
write(iunit) tmp(:,:,:)
166166
close(iunit)
167167
call ezfio_set_ao_two_e_ints_io_ao_cholesky('Read')
168+
call ezfio_set_ao_two_e_ints_do_ao_cholesky(.True.)
168169

169170
deallocate(Vi, V, tmp)
170171
print *, 'Cholesky AO integrals read from TREXIO file'
@@ -206,6 +207,7 @@ subroutine run(f)
206207

207208
call map_save_to_disk(trim(ezfio_filename)//'/work/ao_ints',ao_integrals_map)
208209
call ezfio_set_ao_two_e_ints_io_ao_two_e_integrals('Read')
210+
call ezfio_set_ao_two_e_ints_do_ao_cholesky(.False.)
209211

210212
deallocate(buffer_i, buffer_values, Vi, V)
211213
print *, 'AO integrals read from TREXIO file'
@@ -274,6 +276,7 @@ subroutine run(f)
274276
write(iunit) tmp(:,:,:)
275277
close(iunit)
276278
call ezfio_set_mo_two_e_ints_io_mo_cholesky('Read')
279+
call ezfio_set_ao_two_e_ints_do_ao_cholesky(.True.)
277280

278281
deallocate(Vi, V, tmp)
279282
print *, 'Cholesky MO integrals read from TREXIO file'
@@ -314,6 +317,7 @@ subroutine run(f)
314317

315318
call map_save_to_disk(trim(ezfio_filename)//'/work/mo_ints',mo_integrals_map)
316319
call ezfio_set_mo_two_e_ints_io_mo_two_e_integrals('Read')
320+
call ezfio_set_ao_two_e_ints_do_ao_cholesky(.False.)
317321
deallocate(buffer_i, buffer_values, Vi, V)
318322
print *, 'MO integrals read from TREXIO file'
319323
endif

0 commit comments

Comments
 (0)