mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-08 20:33:26 +01:00
Commented out sqrt(N) algorithm
This commit is contained in:
parent
7801c57de9
commit
bdd1985ded
@ -322,55 +322,55 @@ subroutine select_singles_and_doubles(i_generator,hole_mask,particle_mask,fock_d
|
|||||||
call bitstring_to_list_ab(hole , hole_list , N_holes , N_int)
|
call bitstring_to_list_ab(hole , hole_list , N_holes , N_int)
|
||||||
call bitstring_to_list_ab(particle, particle_list, N_particles, N_int)
|
call bitstring_to_list_ab(particle, particle_list, N_particles, N_int)
|
||||||
|
|
||||||
integer :: l_a, nmax
|
! integer :: l_a, nmax
|
||||||
integer, allocatable :: indices(:), exc_degree(:), iorder(:)
|
! integer, allocatable :: indices(:), exc_degree(:), iorder(:)
|
||||||
allocate (indices(N_det), &
|
! allocate (indices(N_det), &
|
||||||
exc_degree(max(N_det_alpha_unique,N_det_beta_unique)))
|
! exc_degree(max(N_det_alpha_unique,N_det_beta_unique)))
|
||||||
k=1
|
! k=1
|
||||||
do i=1,N_det_alpha_unique
|
! do i=1,N_det_alpha_unique
|
||||||
call get_excitation_degree_spin(psi_det_alpha_unique(1,i), &
|
! call get_excitation_degree_spin(psi_det_alpha_unique(1,i), &
|
||||||
psi_det_generators(1,1,i_generator), exc_degree(i), N_int)
|
! psi_det_generators(1,1,i_generator), exc_degree(i), N_int)
|
||||||
enddo
|
! enddo
|
||||||
|
!
|
||||||
do j=1,N_det_beta_unique
|
! do j=1,N_det_beta_unique
|
||||||
call get_excitation_degree_spin(psi_det_beta_unique(1,j), &
|
! call get_excitation_degree_spin(psi_det_beta_unique(1,j), &
|
||||||
psi_det_generators(1,2,i_generator), nt, N_int)
|
! psi_det_generators(1,2,i_generator), nt, N_int)
|
||||||
if (nt > 2) cycle
|
! if (nt > 2) cycle
|
||||||
do l_a=psi_bilinear_matrix_columns_loc(j), psi_bilinear_matrix_columns_loc(j+1)-1
|
! do l_a=psi_bilinear_matrix_columns_loc(j), psi_bilinear_matrix_columns_loc(j+1)-1
|
||||||
i = psi_bilinear_matrix_rows(l_a)
|
! i = psi_bilinear_matrix_rows(l_a)
|
||||||
if (nt + exc_degree(i) <= 4) then
|
! if (nt + exc_degree(i) <= 4) then
|
||||||
indices(k) = psi_det_sorted_order(psi_bilinear_matrix_order(l_a))
|
! indices(k) = psi_det_sorted_order(psi_bilinear_matrix_order(l_a))
|
||||||
k=k+1
|
! k=k+1
|
||||||
endif
|
! endif
|
||||||
enddo
|
! enddo
|
||||||
enddo
|
! enddo
|
||||||
|
!
|
||||||
do i=1,N_det_beta_unique
|
! do i=1,N_det_beta_unique
|
||||||
call get_excitation_degree_spin(psi_det_beta_unique(1,i), &
|
! call get_excitation_degree_spin(psi_det_beta_unique(1,i), &
|
||||||
psi_det_generators(1,2,i_generator), exc_degree(i), N_int)
|
! psi_det_generators(1,2,i_generator), exc_degree(i), N_int)
|
||||||
enddo
|
! enddo
|
||||||
|
!
|
||||||
do j=1,N_det_alpha_unique
|
! do j=1,N_det_alpha_unique
|
||||||
call get_excitation_degree_spin(psi_det_alpha_unique(1,j), &
|
! call get_excitation_degree_spin(psi_det_alpha_unique(1,j), &
|
||||||
psi_det_generators(1,1,i_generator), nt, N_int)
|
! psi_det_generators(1,1,i_generator), nt, N_int)
|
||||||
if (nt > 1) cycle
|
! if (nt > 1) cycle
|
||||||
do l_a=psi_bilinear_matrix_transp_rows_loc(j), psi_bilinear_matrix_transp_rows_loc(j+1)-1
|
! do l_a=psi_bilinear_matrix_transp_rows_loc(j), psi_bilinear_matrix_transp_rows_loc(j+1)-1
|
||||||
i = psi_bilinear_matrix_transp_columns(l_a)
|
! i = psi_bilinear_matrix_transp_columns(l_a)
|
||||||
if (exc_degree(i) < 3) cycle
|
! if (exc_degree(i) < 3) cycle
|
||||||
if (nt + exc_degree(i) <= 4) then
|
! if (nt + exc_degree(i) <= 4) then
|
||||||
indices(k) = psi_det_sorted_order( &
|
! indices(k) = psi_det_sorted_order( &
|
||||||
psi_bilinear_matrix_order( &
|
! psi_bilinear_matrix_order( &
|
||||||
psi_bilinear_matrix_transp_order(l_a)))
|
! psi_bilinear_matrix_transp_order(l_a)))
|
||||||
k=k+1
|
! k=k+1
|
||||||
endif
|
! endif
|
||||||
enddo
|
! enddo
|
||||||
enddo
|
! enddo
|
||||||
nmax=k-1
|
! nmax=k-1
|
||||||
allocate(iorder(nmax))
|
! allocate(iorder(nmax))
|
||||||
do i=1,nmax
|
! do i=1,nmax
|
||||||
iorder(i) = i
|
! iorder(i) = i
|
||||||
enddo
|
! enddo
|
||||||
call isort(indices,iorder,nmax)
|
! call isort(indices,iorder,nmax)
|
||||||
|
|
||||||
|
|
||||||
preinteresting(0) = 0
|
preinteresting(0) = 0
|
||||||
@ -381,8 +381,9 @@ subroutine select_singles_and_doubles(i_generator,hole_mask,particle_mask,fock_d
|
|||||||
negMask(i,2) = not(psi_det_generators(i,2,i_generator))
|
negMask(i,2) = not(psi_det_generators(i,2,i_generator))
|
||||||
end do
|
end do
|
||||||
|
|
||||||
do k=1,nmax
|
! do k=1,nmax
|
||||||
i = indices(k)
|
! i = indices(k)
|
||||||
|
do i=1,N_det
|
||||||
mobMask(1,1) = iand(negMask(1,1), psi_det_sorted(1,1,i))
|
mobMask(1,1) = iand(negMask(1,1), psi_det_sorted(1,1,i))
|
||||||
mobMask(1,2) = iand(negMask(1,2), psi_det_sorted(1,2,i))
|
mobMask(1,2) = iand(negMask(1,2), psi_det_sorted(1,2,i))
|
||||||
nt = popcnt(mobMask(1, 1)) + popcnt(mobMask(1, 2))
|
nt = popcnt(mobMask(1, 1)) + popcnt(mobMask(1, 2))
|
||||||
|
Loading…
Reference in New Issue
Block a user