mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-12 22:18:31 +01:00
Check for duplicates in parallel
This commit is contained in:
parent
9a70059a11
commit
8274044a7c
@ -192,8 +192,8 @@ subroutine copy_H_apply_buffer_to_wf
|
|||||||
call normalize(psi_coef,N_det)
|
call normalize(psi_coef,N_det)
|
||||||
SOFT_TOUCH N_det psi_det psi_coef
|
SOFT_TOUCH N_det psi_det psi_coef
|
||||||
|
|
||||||
! logical :: found_duplicates
|
logical :: found_duplicates
|
||||||
! call remove_duplicates_in_psi_det(found_duplicates)
|
call remove_duplicates_in_psi_det(found_duplicates)
|
||||||
end
|
end
|
||||||
|
|
||||||
subroutine remove_duplicates_in_psi_det(found_duplicates)
|
subroutine remove_duplicates_in_psi_det(found_duplicates)
|
||||||
@ -205,16 +205,24 @@ subroutine remove_duplicates_in_psi_det(found_duplicates)
|
|||||||
integer :: i,j,k
|
integer :: i,j,k
|
||||||
integer(bit_kind), allocatable :: bit_tmp(:)
|
integer(bit_kind), allocatable :: bit_tmp(:)
|
||||||
logical,allocatable :: duplicate(:)
|
logical,allocatable :: duplicate(:)
|
||||||
|
logical :: dup
|
||||||
|
|
||||||
allocate (duplicate(N_det), bit_tmp(N_det))
|
allocate (duplicate(N_det), bit_tmp(N_det))
|
||||||
|
|
||||||
|
found_duplicates = .False.
|
||||||
|
|
||||||
|
!$OMP PARALLEL DEFAULT(SHARED) PRIVATE(i,j,k,dup)
|
||||||
|
|
||||||
|
!$OMP DO
|
||||||
do i=1,N_det
|
do i=1,N_det
|
||||||
integer, external :: det_search_key
|
integer, external :: det_search_key
|
||||||
!$DIR FORCEINLINE
|
!$DIR FORCEINLINE
|
||||||
bit_tmp(i) = det_search_key(psi_det_sorted_bit(1,1,i),N_int)
|
bit_tmp(i) = det_search_key(psi_det_sorted_bit(1,1,i),N_int)
|
||||||
duplicate(i) = .False.
|
duplicate(i) = .False.
|
||||||
enddo
|
enddo
|
||||||
|
!$OMP END DO
|
||||||
|
|
||||||
|
!$OMP DO
|
||||||
do i=1,N_det-1
|
do i=1,N_det-1
|
||||||
if (duplicate(i)) then
|
if (duplicate(i)) then
|
||||||
cycle
|
cycle
|
||||||
@ -229,28 +237,26 @@ subroutine remove_duplicates_in_psi_det(found_duplicates)
|
|||||||
cycle
|
cycle
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
duplicate(j) = .True.
|
dup = .True.
|
||||||
do k=1,N_int
|
do k=1,N_int
|
||||||
if ( (psi_det_sorted_bit(k,1,i) /= psi_det_sorted_bit(k,1,j) ) &
|
if ( (psi_det_sorted_bit(k,1,i) /= psi_det_sorted_bit(k,1,j) ) &
|
||||||
.or. (psi_det_sorted_bit(k,2,i) /= psi_det_sorted_bit(k,2,j) ) ) then
|
.or. (psi_det_sorted_bit(k,2,i) /= psi_det_sorted_bit(k,2,j) ) ) then
|
||||||
duplicate(j) = .False.
|
dup = .False.
|
||||||
exit
|
exit
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
if (dup) then
|
||||||
|
duplicate(j) = .True.
|
||||||
|
found_duplicates = .True.
|
||||||
|
endif
|
||||||
j += 1
|
j += 1
|
||||||
if (j > N_det) then
|
if (j > N_det) then
|
||||||
exit
|
exit
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
!$OMP END DO
|
||||||
found_duplicates = .False.
|
!$OMP END PARALLEL
|
||||||
do i=1,N_det
|
|
||||||
if (duplicate(i)) then
|
|
||||||
found_duplicates = .True.
|
|
||||||
exit
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
|
|
||||||
if (found_duplicates) then
|
if (found_duplicates) then
|
||||||
k=0
|
k=0
|
||||||
@ -259,14 +265,16 @@ subroutine remove_duplicates_in_psi_det(found_duplicates)
|
|||||||
k += 1
|
k += 1
|
||||||
psi_det(:,:,k) = psi_det_sorted_bit (:,:,i)
|
psi_det(:,:,k) = psi_det_sorted_bit (:,:,i)
|
||||||
psi_coef(k,:) = psi_coef_sorted_bit(i,:)
|
psi_coef(k,:) = psi_coef_sorted_bit(i,:)
|
||||||
else
|
! else
|
||||||
call debug_det(psi_det_sorted_bit(1,1,i),N_int)
|
! call debug_det(psi_det_sorted_bit(1,1,i),N_int)
|
||||||
stop 'duplicates in psi_det'
|
! stop 'duplicates in psi_det'
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
N_det = k
|
N_det = k
|
||||||
call write_bool(6,found_duplicates,'Found duplicate determinants')
|
call write_bool(6,found_duplicates,'Found duplicate determinants')
|
||||||
SOFT_TOUCH N_det psi_det psi_coef
|
psi_det_sorted_bit(:,:,1:N_det) = psi_det(:,:,1:N_det)
|
||||||
|
psi_coef_sorted_bit(1:N_det,:) = psi_coef(1:N_det,:)
|
||||||
|
SOFT_TOUCH N_det psi_det psi_coef psi_det_sorted_bit psi_coef_sorted_bit
|
||||||
endif
|
endif
|
||||||
deallocate (duplicate,bit_tmp)
|
deallocate (duplicate,bit_tmp)
|
||||||
end
|
end
|
||||||
|
@ -167,17 +167,22 @@ end
|
|||||||
integer*8, external :: occ_pattern_search_key
|
integer*8, external :: occ_pattern_search_key
|
||||||
integer(bit_kind), allocatable :: tmp_array(:,:,:)
|
integer(bit_kind), allocatable :: tmp_array(:,:,:)
|
||||||
logical,allocatable :: duplicate(:)
|
logical,allocatable :: duplicate(:)
|
||||||
|
logical :: dup
|
||||||
|
|
||||||
|
|
||||||
allocate ( iorder(N_det), duplicate(N_det), bit_tmp(N_det), tmp_array(N_int,2,N_det) )
|
allocate ( iorder(N_det), duplicate(N_det), bit_tmp(N_det), tmp_array(N_int,2,N_det) )
|
||||||
|
|
||||||
do i=1,N_det
|
do i=1,N_det
|
||||||
iorder(i) = i
|
iorder(i) = i
|
||||||
!$DIR FORCEINLINE
|
|
||||||
bit_tmp(i) = occ_pattern_search_key(psi_occ_pattern(1,1,i),N_int)
|
bit_tmp(i) = occ_pattern_search_key(psi_occ_pattern(1,1,i),N_int)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
call i8sort(bit_tmp,iorder,N_det)
|
call i8sort(bit_tmp,iorder,N_det)
|
||||||
!DIR$ IVDEP
|
|
||||||
|
|
||||||
|
!$OMP PARALLEL DEFAULT(shared) PRIVATE(i,j,k,dup)
|
||||||
|
|
||||||
|
!$OMP DO
|
||||||
do i=1,N_det
|
do i=1,N_det
|
||||||
do k=1,N_int
|
do k=1,N_int
|
||||||
tmp_array(k,1,i) = psi_occ_pattern(k,1,iorder(i))
|
tmp_array(k,1,i) = psi_occ_pattern(k,1,iorder(i))
|
||||||
@ -185,8 +190,10 @@ end
|
|||||||
enddo
|
enddo
|
||||||
duplicate(i) = .False.
|
duplicate(i) = .False.
|
||||||
enddo
|
enddo
|
||||||
|
!$OMP END DO
|
||||||
|
|
||||||
! Find duplicates
|
! Find duplicates
|
||||||
|
!$OMP DO
|
||||||
do i=1,N_det-1
|
do i=1,N_det-1
|
||||||
if (duplicate(i)) then
|
if (duplicate(i)) then
|
||||||
cycle
|
cycle
|
||||||
@ -200,20 +207,25 @@ end
|
|||||||
endif
|
endif
|
||||||
cycle
|
cycle
|
||||||
endif
|
endif
|
||||||
duplicate(j) = .True.
|
dup = .True.
|
||||||
do k=1,N_int
|
do k=1,N_int
|
||||||
if ( (tmp_array(k,1,i) /= tmp_array(k,1,j)) &
|
if ( (tmp_array(k,1,i) /= tmp_array(k,1,j)) &
|
||||||
.or. (tmp_array(k,2,i) /= tmp_array(k,2,j)) ) then
|
.or. (tmp_array(k,2,i) /= tmp_array(k,2,j)) ) then
|
||||||
duplicate(j) = .False.
|
dup = .False.
|
||||||
exit
|
exit
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
if (dup) then
|
||||||
|
duplicate(j) = .True.
|
||||||
|
endif
|
||||||
j+=1
|
j+=1
|
||||||
if (j>N_det) then
|
if (j>N_det) then
|
||||||
exit
|
exit
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
!$OMP END DO
|
||||||
|
!$OMP END PARALLEL
|
||||||
|
|
||||||
! Copy filtered result
|
! Copy filtered result
|
||||||
N_occ_pattern=0
|
N_occ_pattern=0
|
||||||
@ -229,6 +241,7 @@ end
|
|||||||
enddo
|
enddo
|
||||||
|
|
||||||
!- Check
|
!- Check
|
||||||
|
! print *, 'Checking for duplicates in occ pattern'
|
||||||
! do i=1,N_occ_pattern
|
! do i=1,N_occ_pattern
|
||||||
! do j=i+1,N_occ_pattern
|
! do j=i+1,N_occ_pattern
|
||||||
! duplicate(1) = .True.
|
! duplicate(1) = .True.
|
||||||
@ -249,6 +262,7 @@ end
|
|||||||
! endif
|
! endif
|
||||||
! enddo
|
! enddo
|
||||||
! enddo
|
! enddo
|
||||||
|
! print *, 'No duplicates'
|
||||||
!-
|
!-
|
||||||
deallocate(iorder,duplicate,bit_tmp,tmp_array)
|
deallocate(iorder,duplicate,bit_tmp,tmp_array)
|
||||||
|
|
||||||
@ -354,7 +368,7 @@ subroutine make_s2_eigenfunction
|
|||||||
!$OMP END PARALLEL
|
!$OMP END PARALLEL
|
||||||
|
|
||||||
call copy_H_apply_buffer_to_wf
|
call copy_H_apply_buffer_to_wf
|
||||||
SOFT_TOUCH N_det psi_coef psi_det
|
SOFT_TOUCH N_det psi_coef psi_det psi_occ_pattern N_occ_pattern
|
||||||
print *, 'Added determinants for S^2'
|
print *, 'Added determinants for S^2'
|
||||||
call write_time(6)
|
call write_time(6)
|
||||||
|
|
||||||
|
@ -696,12 +696,10 @@ subroutine fill_buffer_double(i_generator, sp, h1, h2, bannedOrb, banned, fock_d
|
|||||||
e_pert = 0.5d0 * (tmp - delta_E)
|
e_pert = 0.5d0 * (tmp - delta_E)
|
||||||
coef = alpha_h_psi / delta_E
|
coef = alpha_h_psi / delta_E
|
||||||
pt2(istate) = pt2(istate) + e_pert
|
pt2(istate) = pt2(istate) + e_pert
|
||||||
|
variance(istate) = variance(istate) + alpha_h_psi * alpha_h_psi
|
||||||
|
norm(istate) = norm(istate) + coef * coef
|
||||||
|
|
||||||
sum_e_pert = sum_e_pert + e_pert * state_average_weight(istate)
|
sum_e_pert = sum_e_pert + e_pert * state_average_weight(istate)
|
||||||
|
|
||||||
variance(istate) = variance(istate) + alpha_h_psi * alpha_h_psi * state_average_weight(istate)
|
|
||||||
norm(istate) = norm(istate) + coef * coef * state_average_weight(istate)
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
|
|
||||||
if(sum_e_pert <= buf%mini) then
|
if(sum_e_pert <= buf%mini) then
|
||||||
|
@ -133,7 +133,6 @@ subroutine ZMQ_selection(N_in, pt2, variance, norm)
|
|||||||
variance(k) = variance(k) * f(k)
|
variance(k) = variance(k) * f(k)
|
||||||
norm(k) = norm(k) * f(k)
|
norm(k) = norm(k) * f(k)
|
||||||
enddo
|
enddo
|
||||||
! variance = variance - pt2*pt2
|
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ subroutine print_summary(e_,pt2_,error_,variance_,norm_)
|
|||||||
do k=1, N_states_p
|
do k=1, N_states_p
|
||||||
print*,'State ',k
|
print*,'State ',k
|
||||||
print *, 'Variance = ', variance_(k)
|
print *, 'Variance = ', variance_(k)
|
||||||
print *, 'PT norm = ', norm_(k)
|
print *, 'PT norm = ', dsqrt(norm_(k))
|
||||||
print *, 'PT2 = ', pt2_(k)
|
print *, 'PT2 = ', pt2_(k)
|
||||||
print *, 'E = ', e_(k)
|
print *, 'E = ', e_(k)
|
||||||
print *, 'E+PT2'//pt2_string//' = ', e_(k)+pt2_(k), ' +/- ', error_(k)
|
print *, 'E+PT2'//pt2_string//' = ', e_(k)+pt2_(k), ' +/- ', error_(k)
|
||||||
|
Loading…
Reference in New Issue
Block a user