mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-10 13:08:23 +01:00
Cleaning in determinants
This commit is contained in:
parent
4f630520d1
commit
dce39c7dd1
10
Makefile
10
Makefile
@ -28,11 +28,11 @@ EZFIO: bin/irpf90
|
|||||||
bin/irpf90:
|
bin/irpf90:
|
||||||
$(info $(BLUE)===== Fetching IRPF90 from the web ===== $(BLACK))
|
$(info $(BLUE)===== Fetching IRPF90 from the web ===== $(BLACK))
|
||||||
@sleep 1
|
@sleep 1
|
||||||
#@$(FETCH_FROM_WEB) "$(WWW_SERVER)/$(IRPF90_TGZ)" $(IRPF90_TGZ) || \
|
@$(FETCH_FROM_WEB) "$(WWW_SERVER)/$(IRPF90_TGZ)" $(IRPF90_TGZ) || \
|
||||||
# (echo Unable to download IRPF90 : $(WWW_SERVER)/$(IRPF90_TGZ) ; exit 1)
|
(echo Unable to download IRPF90 : $(WWW_SERVER)/$(IRPF90_TGZ) ; exit 1)
|
||||||
#tar -zxf $(IRPF90_TGZ) && rm $(IRPF90_TGZ)
|
tar -zxf $(IRPF90_TGZ) && rm $(IRPF90_TGZ)
|
||||||
#$(MAKE) -C irpf90 | tee install_irpf90.log
|
$(MAKE) -C irpf90 | tee install_irpf90.log
|
||||||
#rm -rf -- $$PWD/bin/irpf90 $$PWD/bin/irpman
|
rm -rf -- $$PWD/bin/irpf90 $$PWD/bin/irpman
|
||||||
echo $$PWD/irpf90/bin/irpf90 $$\@ > $$PWD/bin/irpf90
|
echo $$PWD/irpf90/bin/irpf90 $$\@ > $$PWD/bin/irpf90
|
||||||
echo $$PWD/irpf90/bin/irpman $$\@ > $$PWD/bin/irpman
|
echo $$PWD/irpf90/bin/irpman $$\@ > $$PWD/bin/irpman
|
||||||
chmod +x $$PWD/bin/irpf90 $$PWD/bin/irpman
|
chmod +x $$PWD/bin/irpf90 $$PWD/bin/irpman
|
||||||
|
@ -147,7 +147,7 @@ BEGIN_PROVIDER [ double precision, psi_coef, (psi_det_size,N_states_diag) ]
|
|||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, psi_average_norm_contrib, (N_det) ]
|
BEGIN_PROVIDER [ double precision, psi_average_norm_contrib, (psi_det_size) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Contribution of determinants to the state-averaged density
|
! Contribution of determinants to the state-averaged density
|
||||||
@ -218,7 +218,7 @@ BEGIN_PROVIDER [ integer(bit_kind), psi_det_beta, (N_int,psi_det_size) ]
|
|||||||
enddo
|
enddo
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ integer(bit_kind), psi_det_alpha_unique, (N_int,N_det) ]
|
BEGIN_PROVIDER [ integer(bit_kind), psi_det_alpha_unique, (N_int,psi_det_size) ]
|
||||||
&BEGIN_PROVIDER [ integer, N_det_alpha_unique ]
|
&BEGIN_PROVIDER [ integer, N_det_alpha_unique ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
@ -255,7 +255,7 @@ END_PROVIDER
|
|||||||
deallocate (iorder, bit_tmp)
|
deallocate (iorder, bit_tmp)
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ integer(bit_kind), psi_det_beta_unique, (N_int,N_det) ]
|
BEGIN_PROVIDER [ integer(bit_kind), psi_det_beta_unique, (N_int,psi_det_size) ]
|
||||||
&BEGIN_PROVIDER [ integer, N_det_beta_unique ]
|
&BEGIN_PROVIDER [ integer, N_det_beta_unique ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
@ -300,9 +300,9 @@ END_PROVIDER
|
|||||||
!==============================================================================!
|
!==============================================================================!
|
||||||
|
|
||||||
|
|
||||||
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted, (N_int,2,N_det) ]
|
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted, (N_int,2,psi_det_size) ]
|
||||||
&BEGIN_PROVIDER [ double precision, psi_coef_sorted, (N_det,N_states) ]
|
&BEGIN_PROVIDER [ double precision, psi_coef_sorted, (psi_det_size,N_states) ]
|
||||||
&BEGIN_PROVIDER [ double precision, psi_average_norm_contrib_sorted, (N_det) ]
|
&BEGIN_PROVIDER [ double precision, psi_average_norm_contrib_sorted, (psi_det_size) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Wave function sorted by determinants contribution to the norm (state-averaged)
|
! Wave function sorted by determinants contribution to the norm (state-averaged)
|
||||||
@ -331,8 +331,8 @@ END_PROVIDER
|
|||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted_bit, (N_int,2,N_det) ]
|
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted_bit, (N_int,2,psi_det_size) ]
|
||||||
&BEGIN_PROVIDER [ double precision, psi_coef_sorted_bit, (N_det,N_states) ]
|
&BEGIN_PROVIDER [ double precision, psi_coef_sorted_bit, (psi_det_size,N_states) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Determinants on which we apply <i|H|psi> for perturbation.
|
! Determinants on which we apply <i|H|psi> for perturbation.
|
||||||
@ -430,9 +430,9 @@ subroutine filter_3_highest_electrons( det_in, det_out, Nint )
|
|||||||
enddo
|
enddo
|
||||||
end
|
end
|
||||||
|
|
||||||
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted_ab, (N_int,2,N_det) ]
|
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted_ab, (N_int,2,psi_det_size) ]
|
||||||
&BEGIN_PROVIDER [ double precision, psi_coef_sorted_ab, (N_det,N_states) ]
|
&BEGIN_PROVIDER [ double precision, psi_coef_sorted_ab, (N_det,N_states) ]
|
||||||
&BEGIN_PROVIDER [ integer, psi_det_sorted_next_ab, (2,N_det) ]
|
&BEGIN_PROVIDER [ integer, psi_det_sorted_next_ab, (2,psi_det_size) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Determinants on which we apply <i|H|j>.
|
! Determinants on which we apply <i|H|j>.
|
||||||
@ -440,31 +440,58 @@ end
|
|||||||
! then by the 3 highest electrons in the beta part to accelerate
|
! then by the 3 highest electrons in the beta part to accelerate
|
||||||
! the research of connected determinants.
|
! the research of connected determinants.
|
||||||
END_DOC
|
END_DOC
|
||||||
|
|
||||||
|
call sort_dets_by_3_highest_electrons( &
|
||||||
|
psi_det, &
|
||||||
|
psi_coef, &
|
||||||
|
psi_det_sorted_ab, &
|
||||||
|
psi_coef_sorted_ab, &
|
||||||
|
psi_det_sorted_next_ab, &
|
||||||
|
N_det, N_states, N_int, &
|
||||||
|
psi_det_size )
|
||||||
|
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
|
subroutine sort_dets_by_3_highest_electrons(det_in,coef_in,det_out,coef_out, &
|
||||||
|
det_next, Ndet, Nstates, Nint, LDA)
|
||||||
|
implicit none
|
||||||
|
integer, intent(in) :: Ndet, Nstates, Nint, LDA
|
||||||
|
integer(bit_kind), intent(in) :: det_in (Nint,2,Ndet)
|
||||||
|
integer(bit_kind), intent(out) :: det_out (Nint,2,Ndet)
|
||||||
|
integer, intent(out) :: det_next (2,Ndet)
|
||||||
|
double precision, intent(in) :: coef_in (LDA,Nstates)
|
||||||
|
double precision, intent(out) :: coef_out (LDA,Nstates)
|
||||||
|
BEGIN_DOC
|
||||||
|
! Determinants on which we apply <i|H|j>.
|
||||||
|
! They are sorted by the 3 highest electrons in the alpha part,
|
||||||
|
! then by the 3 highest electrons in the beta part to accelerate
|
||||||
|
! the research of connected determinants.
|
||||||
|
END_DOC
|
||||||
integer :: i,j,k
|
integer :: i,j,k
|
||||||
integer, allocatable :: iorder(:)
|
integer, allocatable :: iorder(:)
|
||||||
integer*8, allocatable :: bit_tmp(:)
|
integer*8, allocatable :: bit_tmp(:)
|
||||||
integer*8, external :: det_search_key
|
integer*8, external :: det_search_key
|
||||||
|
|
||||||
allocate ( iorder(N_det), bit_tmp(N_det) )
|
allocate ( iorder(Ndet), bit_tmp(Ndet) )
|
||||||
|
|
||||||
! Sort alpha dets
|
! Sort alpha dets
|
||||||
! ---------------
|
! ---------------
|
||||||
|
|
||||||
integer(bit_kind) :: det_tmp(N_int)
|
integer(bit_kind) :: det_tmp(Nint)
|
||||||
|
|
||||||
do i=1,N_det
|
do i=1,Ndet
|
||||||
iorder(i) = i
|
iorder(i) = i
|
||||||
call int_of_3_highest_electrons(psi_det(1,1,i),bit_tmp(i),N_int)
|
call int_of_3_highest_electrons(psi_det(1,1,i),bit_tmp(i),N_int)
|
||||||
enddo
|
enddo
|
||||||
call i8sort(bit_tmp,iorder,N_det)
|
call i8sort(bit_tmp,iorder,Ndet)
|
||||||
!DIR$ IVDEP
|
!DIR$ IVDEP
|
||||||
do i=1,N_det
|
do i=1,Ndet
|
||||||
do j=1,N_int
|
do j=1,N_int
|
||||||
psi_det_sorted_ab(j,1,i) = psi_det(j,1,iorder(i))
|
det_out(j,1,i) = psi_det(j,1,iorder(i))
|
||||||
psi_det_sorted_ab(j,2,i) = psi_det(j,2,iorder(i))
|
det_out(j,2,i) = psi_det(j,2,iorder(i))
|
||||||
enddo
|
enddo
|
||||||
do k=1,N_states
|
do k=1,Nstates
|
||||||
psi_coef_sorted_ab(i,k) = psi_coef(iorder(i),k)
|
coef_out(i,k) = psi_coef(iorder(i),k)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
@ -473,60 +500,60 @@ end
|
|||||||
|
|
||||||
integer :: next
|
integer :: next
|
||||||
|
|
||||||
next = N_det+1
|
next = Ndet+1
|
||||||
psi_det_sorted_next_ab(1,N_det) = next
|
det_next(1,Ndet) = next
|
||||||
do i=N_det-1,1,-1
|
do i=Ndet-1,1,-1
|
||||||
if (bit_tmp(i) /= bit_tmp(i+1)) then
|
if (bit_tmp(i) /= bit_tmp(i+1)) then
|
||||||
next = i+1
|
next = i+1
|
||||||
endif
|
endif
|
||||||
psi_det_sorted_next_ab(1,i) = next
|
det_next(1,i) = next
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
! Sort beta dets
|
! Sort beta dets
|
||||||
! --------------
|
! --------------
|
||||||
|
|
||||||
integer :: istart, iend
|
integer :: istart, iend
|
||||||
integer(bit_kind), allocatable :: psi_det_sorted_ab_temp (:,:)
|
integer(bit_kind), allocatable :: det_sorted_temp (:,:)
|
||||||
|
|
||||||
allocate ( psi_det_sorted_ab_temp (N_int,N_det) )
|
allocate ( det_sorted_temp (N_int,Ndet) )
|
||||||
do i=1,N_det
|
do i=1,Ndet
|
||||||
do j=1,N_int
|
do j=1,N_int
|
||||||
psi_det_sorted_ab_temp(j,i) = psi_det_sorted_ab(j,2,i)
|
det_sorted_temp(j,i) = det_out(j,2,i)
|
||||||
enddo
|
enddo
|
||||||
iorder(i) = i
|
iorder(i) = i
|
||||||
call int_of_3_highest_electrons(psi_det_sorted_ab_temp(1,i),bit_tmp(i),N_int)
|
call int_of_3_highest_electrons(det_sorted_temp(1,i),bit_tmp(i),N_int)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
istart=1
|
istart=1
|
||||||
do while ( istart<N_det )
|
do while ( istart<Ndet )
|
||||||
|
|
||||||
iend = psi_det_sorted_next_ab(1,istart)
|
iend = det_next(1,istart)
|
||||||
call i8sort(bit_tmp(istart),iorder(istart),iend-istart)
|
call i8sort(bit_tmp(istart),iorder(istart),iend-istart)
|
||||||
!DIR$ IVDEP
|
!DIR$ IVDEP
|
||||||
do i=istart,iend-1
|
do i=istart,iend-1
|
||||||
do j=1,N_int
|
do j=1,N_int
|
||||||
psi_det_sorted_ab(j,2,i) = psi_det_sorted_ab_temp(j,iorder(i))
|
det_out(j,2,i) = det_sorted_temp(j,iorder(i))
|
||||||
enddo
|
enddo
|
||||||
do k=1,N_states
|
do k=1,Nstates
|
||||||
psi_coef_sorted_ab(i,k) = psi_coef(iorder(i),k)
|
coef_out(i,k) = psi_coef(iorder(i),k)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
next = iend
|
next = iend
|
||||||
psi_det_sorted_next_ab(2,iend-1) = next
|
det_next(2,iend-1) = next
|
||||||
do i=iend-2,1,-1
|
do i=iend-2,1,-1
|
||||||
if (bit_tmp(i) /= bit_tmp(i+1)) then
|
if (bit_tmp(i) /= bit_tmp(i+1)) then
|
||||||
next = i+1
|
next = i+1
|
||||||
endif
|
endif
|
||||||
psi_det_sorted_next_ab(2,i) = next
|
det_next(2,i) = next
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
istart = iend
|
istart = iend
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
deallocate(iorder, bit_tmp, psi_det_sorted_ab_temp)
|
deallocate(iorder, bit_tmp, det_sorted_temp)
|
||||||
|
|
||||||
END_PROVIDER
|
end
|
||||||
|
|
||||||
!==============================================================================!
|
!==============================================================================!
|
||||||
! !
|
! !
|
||||||
|
@ -165,14 +165,12 @@ subroutine filter_connected_davidson(key1,key2,Nint,sze,idx)
|
|||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Filters out the determinants that are not connected by H
|
! Filters out the determinants that are not connected by H
|
||||||
!
|
|
||||||
! returns the array idx which contains the index of the
|
! returns the array idx which contains the index of the
|
||||||
!
|
|
||||||
! determinants in the array key1 that interact
|
! determinants in the array key1 that interact
|
||||||
!
|
|
||||||
! via the H operator with key2.
|
! via the H operator with key2.
|
||||||
!
|
!
|
||||||
! idx(0) is the number of determinants that interact with key1
|
! idx(0) is the number of determinants that interact with key1
|
||||||
|
! key1 should come from psi_det_sorted_ab.
|
||||||
END_DOC
|
END_DOC
|
||||||
integer, intent(in) :: Nint, sze
|
integer, intent(in) :: Nint, sze
|
||||||
integer(bit_kind), intent(in) :: key1(Nint,2,sze)
|
integer(bit_kind), intent(in) :: key1(Nint,2,sze)
|
||||||
|
@ -207,7 +207,7 @@ end
|
|||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
j+=1
|
j+=1
|
||||||
if (j>N_det) then
|
if (j>=N_det) then
|
||||||
exit
|
exit
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
Loading…
Reference in New Issue
Block a user