mirror of
https://github.com/pfloos/quack
synced 2025-01-03 01:55:57 +01:00
working on optim Fock matrix
This commit is contained in:
parent
37420d1207
commit
956cebf664
@ -47,92 +47,103 @@ subroutine Hartree_matrix_AO_basis_hpc(nBas, ERI_size, P, ERI_chem, H)
|
||||
|
||||
integer :: mu, nu, la, si
|
||||
integer :: nunu, lala, nula, lasi, numu
|
||||
integer :: nunu0, lala0
|
||||
integer*8 :: nunununu, nunulala, nununula, nunulasi
|
||||
integer*8 :: lalanunu, lasinunu, numulala, lalanumu
|
||||
integer*8 :: numunula, numulasi, lasinumu, nununumu
|
||||
integer*8 :: munu0, munu
|
||||
integer*8 :: sila0, sila
|
||||
integer*8 :: munulasi0, munulasi
|
||||
integer*8 :: nunununu0, numunumu0
|
||||
|
||||
|
||||
do nu = 1, nBas
|
||||
|
||||
nunu = (nu * (nu - 1)) / 2 + nu
|
||||
nunununu = (nunu * (nunu - 1)) / 2 + nunu
|
||||
nunu0 = shiftr(nu * (nu - 1), 1)
|
||||
nunu = nunu0 + nu
|
||||
nunununu0 = shiftr(nunu * (nunu - 1), 1)
|
||||
|
||||
nunununu = nunununu0 + nunu
|
||||
H(nu,nu) = P(nu,nu) * ERI_chem(nunununu)
|
||||
|
||||
do la = 1, nu-1
|
||||
|
||||
lala = (la * (la - 1)) / 2 + la
|
||||
nunulala = (nunu * (nunu - 1)) / 2 + lala
|
||||
lala0 = shiftr(la * (la - 1), 1)
|
||||
|
||||
lala = lala0 + la
|
||||
nunulala = nunununu0 + lala
|
||||
H(nu,nu) = H(nu,nu) + P(la,la) * ERI_chem(nunulala)
|
||||
|
||||
nula = (nu * (nu - 1)) / 2 + la
|
||||
nununula = (nunu * (nunu - 1)) / 2 + nula
|
||||
nula = nunu0 + la
|
||||
nununula = nunununu0 + nula
|
||||
H(nu,nu) = H(nu,nu) + 2.d0 * P(la,nu) * ERI_chem(nununula)
|
||||
|
||||
do si = 1, la - 1
|
||||
lasi = (la * (la - 1)) / 2 + si
|
||||
nunulasi = (nunu * (nunu - 1)) / 2 + lasi
|
||||
lasi = lala0 + si
|
||||
nunulasi = nunununu0 + lasi
|
||||
H(nu,nu) = H(nu,nu) + 2.d0 * P(si,la) * ERI_chem(nunulasi)
|
||||
enddo
|
||||
enddo
|
||||
|
||||
do la = nu + 1, nBas
|
||||
|
||||
lala = (la * (la - 1)) / 2 + la
|
||||
lalanunu = (lala * (lala - 1)) / 2 + nunu
|
||||
lala0 = shiftr(la * (la - 1), 1)
|
||||
|
||||
lala = lala0 + la
|
||||
lalanunu = shiftr(lala * (lala - 1), 1) + nunu
|
||||
H(nu,nu) = H(nu,nu) + P(la,la) * ERI_chem(lalanunu)
|
||||
|
||||
do si = 1, la - 1
|
||||
lasi = (la * (la - 1)) / 2 + si
|
||||
lasinunu = (lasi * (lasi - 1)) / 2 + nunu
|
||||
lasi = lala0 + si
|
||||
lasinunu = shiftr(lasi * (lasi - 1), 1) + nunu
|
||||
H(nu,nu) = H(nu,nu) + 2.d0 * P(si,la) * ERI_chem(lasinunu)
|
||||
enddo
|
||||
enddo
|
||||
|
||||
do mu = 1, nu - 1
|
||||
|
||||
numu = (nu * (nu - 1)) / 2 + mu
|
||||
nununumu = (nunu * (nunu - 1)) / 2 + numu
|
||||
numu = nunu0 + mu
|
||||
|
||||
numunumu0 = shiftr(numu * (numu - 1), 1)
|
||||
|
||||
nununumu = nunununu0 + numu
|
||||
H(mu,nu) = p(nu,nu) * ERI_chem(nununumu)
|
||||
|
||||
do la = 1, nu - 1
|
||||
lala = (la * (la - 1)) / 2 + la
|
||||
numulala = (numu * (numu - 1)) / 2 + lala
|
||||
lala = shiftr(la * (la - 1), 1) + la
|
||||
numulala = numunumu0 + lala
|
||||
H(mu,nu) = H(mu,nu) + p(la,la) * ERI_chem(numulala)
|
||||
enddo
|
||||
|
||||
do la = nu + 1, nBas
|
||||
lala = (la * (la - 1)) / 2 + la
|
||||
lalanumu = (lala * (lala - 1)) / 2 + numu
|
||||
lala = shiftr(la * (la - 1), 1) + la
|
||||
lalanumu = shiftr(lala * (lala - 1), 1) + numu
|
||||
H(mu,nu) = H(mu,nu) + p(la,la) * ERI_chem(lalanumu)
|
||||
enddo
|
||||
|
||||
do la = 1, mu
|
||||
nula = (nu * (nu - 1)) / 2 + la
|
||||
numunula = (numu * (numu - 1)) / 2 + nula
|
||||
nula = nunu0 + la
|
||||
numunula = numunumu0 + nula
|
||||
H(mu,nu) = H(mu,nu) + 2.d0 * P(la,nu) * ERI_chem(numunula)
|
||||
enddo
|
||||
|
||||
do la = mu + 1, nu - 1
|
||||
nula = (nu * (nu - 1)) / 2 + la
|
||||
numunula = (nula * (nula - 1)) / 2 + numu
|
||||
nula = nunu0 + la
|
||||
numunula = shiftr(nula * (nula - 1), 1) + numu
|
||||
H(mu,nu) = H(mu,nu) + 2.d0 * P(la,nu) * ERI_chem(numunula)
|
||||
enddo
|
||||
|
||||
do la = 2, nu - 1
|
||||
lala0 = shiftr(la * (la - 1), 1)
|
||||
do si = 1, la - 1
|
||||
lasi = (la * (la - 1)) / 2 + si
|
||||
numulasi = (numu * (numu - 1)) / 2 + lasi
|
||||
lasi = lala0 + si
|
||||
numulasi = numunumu0 + lasi
|
||||
H(mu,nu) = H(mu,nu) + 2.d0 * P(si,la) * ERI_chem(numulasi)
|
||||
enddo
|
||||
enddo
|
||||
|
||||
do la = nu + 1, nBas
|
||||
lala0 = shiftr(la * (la - 1), 1)
|
||||
do si = 1, la - 1
|
||||
lasi = (la * (la - 1)) / 2 + si
|
||||
lasinumu = (lasi * (lasi - 1)) / 2 + numu
|
||||
lasi = lala0 + si
|
||||
lasinumu = shiftr(lasi * (lasi - 1), 1) + numu
|
||||
H(mu,nu) = H(mu,nu) + 2.d0 * P(si,la) * ERI_chem(lasinumu)
|
||||
enddo
|
||||
enddo
|
||||
|
Loading…
Reference in New Issue
Block a user