|
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 ] |
9 | 2 |
|
10 | 3 | use bitmasks
|
11 | 4 | implicit none
|
12 | 5 | BEGIN_DOC
|
13 |
| - ! Energy of the reference bitmask used in Slater rules |
| 6 | + ! One-electron energy of the reference bitmask used in Slater rules |
14 | 7 | END_DOC
|
15 | 8 |
|
16 | 9 | integer :: occ(N_int*bit_kind_size,2)
|
17 |
| - integer :: i,j |
| 10 | + integer :: i |
18 | 11 |
|
19 | 12 | call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
|
20 | 13 | call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)
|
21 | 14 |
|
22 | 15 |
|
23 |
| - ref_bitmask_energy = 0.d0 |
24 | 16 | 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 | + |
25 | 43 | ref_bitmask_kinetic_energy = 0.d0
|
26 |
| - ref_bitmask_n_e_energy = 0.d0 |
27 |
| - ref_bitmask_two_e_energy = 0.d0 |
28 | 44 |
|
29 | 45 | 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)) |
31 | 46 | 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 |
32 | 73 | 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 |
33 | 99 | do j = i+1, elec_alpha_num
|
34 | 100 | 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)) |
36 | 101 | enddo
|
37 | 102 | do j= 1, elec_alpha_num
|
38 | 103 | 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)) |
40 | 104 | enddo
|
41 | 105 | do j = i+1, elec_beta_num
|
42 | 106 | 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)) |
44 | 107 | enddo
|
45 | 108 | enddo
|
46 | 109 |
|
47 | 110 | 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)) |
51 | 111 | do j = i+1, elec_alpha_num
|
52 | 112 | 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)) |
54 | 113 | enddo
|
55 | 114 | enddo
|
56 | 115 |
|
57 |
| - ref_bitmask_one_e_energy = ref_bitmask_kinetic_energy + ref_bitmask_n_e_energy |
| 116 | +END_PROVIDER |
58 | 117 |
|
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 |
63 | 139 | enddo
|
64 |
| - enddo |
65 | 140 |
|
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 |
70 | 146 | 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 |
73 | 148 |
|
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 |
78 | 154 | 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 |
81 | 166 |
|
| 167 | + ref_bitmask_energy = ref_bitmask_one_e_energy + ref_bitmask_two_e_energy |
82 | 168 |
|
83 | 169 |
|
84 | 170 | END_PROVIDER
|
|
0 commit comments