9
1
mirror of https://github.com/QuantumPackage/qp2.git synced 2025-01-05 09:58:42 +01:00

Fixed bugs in obtain I.

This commit is contained in:
v1j4y 2022-12-19 13:54:34 +01:00
parent 6f86f05e7f
commit 0f600519cb

View File

@ -264,15 +264,15 @@ subroutine obtain_connected_I_foralpha(idxI, Ialpha, connectedI, idxs_connectedI
Icfg = Ialpha Icfg = Ialpha
Nsomo_alpha = 0 Nsomo_alpha = 0
!print *," Ialpha=" !print *," Ialpha="
do i=1,N_int do ii=1,N_int
Isomo = Ialpha(i,1) Isomo = Ialpha(ii,1)
Idomo = Ialpha(i,2) Idomo = Ialpha(ii,2)
Nsomo_alpha += POPCNT(Isomo) Nsomo_alpha += POPCNT(Isomo)
!print *,Isomo, Idomo, "Nsomo=",Nsomo_alpha !print *,Isomo, Idomo, "Nsomo=",Nsomo_alpha
end do end do
end_index = min(N_configuration,cfg_seniority_index(min(Nsomo_alpha+4,elec_num))-1) end_index = min(N_configuration,cfg_seniority_index(min(Nsomo_alpha+4,elec_num))-1)
if(end_index .LT. 0) end_index= N_configuration if(end_index .LT. 0 .OR. end_index .lt. idxI) end_index= N_configuration
!end_index = N_configuration end_index = N_configuration
p = 0 p = 0
@ -283,17 +283,6 @@ subroutine obtain_connected_I_foralpha(idxI, Ialpha, connectedI, idxs_connectedI
if(Nsomo_alpha .lt. MS)then if(Nsomo_alpha .lt. MS)then
cycle cycle
endif endif
!Isomo = Ialpha(1,1)
!Idomo = Ialpha(1,2)
!Jsomo = psi_configuration(1,1,i)
!Jdomo = psi_configuration(1,2,i)
!diffSOMO = IEOR(Isomo,Jsomo)
!ndiffSOMO = POPCNT(diffSOMO)
!diffDOMO = IEOR(Idomo,Jdomo)
!xordiffSOMODOMO = IEOR(diffSOMO,diffDOMO)
!ndiffDOMO = POPCNT(diffDOMO)
!nxordiffSOMODOMO = POPCNT(xordiffSOMODOMO)
!nxordiffSOMODOMO += ndiffSOMO + ndiffDOMO
ndiffSOMO = 0 ndiffSOMO = 0
ndiffDOMO = 0 ndiffDOMO = 0
@ -315,6 +304,9 @@ subroutine obtain_connected_I_foralpha(idxI, Ialpha, connectedI, idxs_connectedI
nxordiffSOMODOMO += POPCNT(xordiffSOMODOMO) nxordiffSOMODOMO += POPCNT(xordiffSOMODOMO)
nxordiffSOMODOMO += POPCNT(diffSOMO) + POPCNT(diffDOMO) nxordiffSOMODOMO += POPCNT(diffSOMO) + POPCNT(diffDOMO)
end do end do
!if(idxI.eq.218)then
! print *,"I=",idxI,"Nsomo_alpha=",Nsomo_alpha,"nxordiffSOMODOMO(4)=",nxordiffSOMODOMO, " ndiffSOMO(2)=",ndiffSOMO, " ndiffDOMO=",ndiffDOMO
!endif
!Jcfg = psi_configuration(:,:,i) !Jcfg = psi_configuration(:,:,i)
!print *,"nxordiffSOMODOMO(4)=",nxordiffSOMODOMO, " ndiffSOMO(2)=",ndiffSOMO !print *,"nxordiffSOMODOMO(4)=",nxordiffSOMODOMO, " ndiffSOMO(2)=",ndiffSOMO
@ -391,14 +383,14 @@ subroutine obtain_connected_I_foralpha(idxI, Ialpha, connectedI, idxs_connectedI
do ii=1,N_int do ii=1,N_int
Isomo = Ialpha(ii,1) Isomo = Ialpha(ii,1)
Jsomo = psi_configuration(ii,1,i) Jsomo = psi_configuration(ii,1,i)
Isomo = IEOR(Isomo, Jsomo) IJsomo = IEOR(Isomo, Jsomo)
iint = shiftr(p-1,bit_kind_shift) + 1 iint = shiftr(p-1,bit_kind_shift) + 1
ipos = p-shiftl((iint-1),bit_kind_shift) ipos = p-shiftl((iint-1),bit_kind_shift)
if(iint .eq. ii)then if(iint .eq. ii)then
Isomo = IBCLR(Isomo,ipos-1) IJsomo = IBCLR(IJsomo,ipos-1)
endif endif
if(popcnt(Isomo) > 0)then if(popcnt(IJsomo) > 0)then
q = TRAILZ(Isomo) + 1 + (ii-1) * bit_kind_size q = TRAILZ(IJsomo) + 1 + (ii-1) * bit_kind_size
EXIT EXIT
endif endif
end do end do
@ -437,15 +429,15 @@ subroutine obtain_connected_I_foralpha(idxI, Ialpha, connectedI, idxs_connectedI
do ii=1,N_int do ii=1,N_int
Isomo = Ialpha(ii,1) Isomo = Ialpha(ii,1)
Jsomo = psi_configuration(ii,1,i) Jsomo = psi_configuration(ii,1,i)
Isomo = IEOR(Isomo, Jsomo) IJsomo = IEOR(Isomo, Jsomo)
iint = shiftr(q-1,bit_kind_shift) + 1 iint = shiftr(q-1,bit_kind_shift) + 1
ipos = q-shiftl((iint-1),bit_kind_shift) ipos = q-shiftl((iint-1),bit_kind_shift)
if(iint .eq. ii)then if(iint .eq. ii)then
Isomo = IBCLR(Isomo,ipos-1) IJsomo = IBCLR(IJsomo,ipos-1)
endif endif
!print *,"ii=",ii," Isomo=",Isomo !print *,"ii=",ii," Isomo=",Isomo
if(popcnt(Isomo) > 0)then if(popcnt(IJsomo) > 0)then
p = TRAILZ(Isomo) + 1 + (ii-1) * bit_kind_size p = TRAILZ(IJsomo) + 1 + (ii-1) * bit_kind_size
EXIT EXIT
endif endif
enddo enddo
@ -502,9 +494,9 @@ subroutine obtain_connected_I_foralpha(idxI, Ialpha, connectedI, idxs_connectedI
endi = psi_config_data(i,2) endi = psi_config_data(i,2)
nconnectedExtradiag+=1 nconnectedExtradiag+=1
nconnectedI += 1 nconnectedI += 1
do k=1,N_int do ii=1,N_int
connectedI(k,1,nconnectedI) = psi_configuration(k,1,i) connectedI(ii,1,nconnectedI) = psi_configuration(ii,1,i)
connectedI(k,2,nconnectedI) = psi_configuration(k,2,i) connectedI(ii,2,nconnectedI) = psi_configuration(ii,2,i)
enddo enddo
idxs_connectedI(nconnectedI)=starti idxs_connectedI(nconnectedI)=starti
excitationIds(1,nconnectedI)=p excitationIds(1,nconnectedI)=p