10
0
mirror of https://github.com/LCPQ/quantum_package synced 2024-12-26 06:14:43 +01:00

det_minilist

This commit is contained in:
Yann Garniron 2018-02-22 15:29:20 +01:00
parent 381c985999
commit bd1aefc567
2 changed files with 30 additions and 20 deletions

View File

@ -387,12 +387,19 @@ subroutine alpha_callback_mask(delta_ij_loc, sp, mask, bannedOrb, banned, indexe
integer :: lindex(mo_tot_num,2), lindex_end(mo_tot_num, 2) integer :: lindex(mo_tot_num,2), lindex_end(mo_tot_num, 2)
integer :: s1, s2, stamo integer :: s1, s2, stamo
logical,allocatable :: putten(:) logical,allocatable :: putten(:)
integer(bit_kind), allocatable :: det_minilist(:,:,:)
allocate(labuf(N_det), putten(N_det))
allocate(labuf(N_det), putten(N_det), det_minilist(N_int, 2, N_det))
putten = .false. putten = .false.
st1 = indexes_end(0,0)-1 !! st1 = indexes_end(0,0)-1 !!
if(st1 > 0) labuf(:st1) = abuf(:st1) if(st1 > 0) then
labuf(:st1) = abuf(:st1)
do i=1,st1
det_minilist(:,:,i) = psi_det_sorted(:,:,labuf(i))
end do
end if
st1 += 1 st1 += 1
if(sp == 3) then if(sp == 3) then
@ -421,6 +428,7 @@ subroutine alpha_callback_mask(delta_ij_loc, sp, mask, bannedOrb, banned, indexe
labuf(st1:st2-1) = abuf(lindex(i,s1):lindex_end(i,s1)) labuf(st1:st2-1) = abuf(lindex(i,s1):lindex_end(i,s1))
do j=st1,st2-1 do j=st1,st2-1
putten(labuf(j)) = .true. putten(labuf(j)) = .true.
det_minilist(:,:,j) = psi_det_sorted(:,:,labuf(j))
end do end do
else else
st2 = st1 st2 = st1
@ -439,11 +447,10 @@ subroutine alpha_callback_mask(delta_ij_loc, sp, mask, bannedOrb, banned, indexe
do k=lindex(j,s2), lindex_end(j,s2) do k=lindex(j,s2), lindex_end(j,s2)
if(.not. putten(abuf(k))) then if(.not. putten(abuf(k))) then
labuf(st3) = abuf(k) labuf(st3) = abuf(k)
det_minilist(:,:,st3) = psi_det_sorted(:,:,abuf(k))
st3 += 1 st3 += 1
end if end if
end do end do
!st3 = st2 + 1 + lindex_end(j,s2)-lindex(j,s2)
!labuf(st2:st3-1) = abuf(lindex(j,s2):lindex_end(j,s2))
else else
st3 = st2 st3 = st2
end if end if
@ -451,6 +458,9 @@ subroutine alpha_callback_mask(delta_ij_loc, sp, mask, bannedOrb, banned, indexe
if(indexes(i,j) /= 0) then if(indexes(i,j) /= 0) then
st4 = st3 + 1 + indexes_end(i,j)-indexes(i,j) -1!! st4 = st3 + 1 + indexes_end(i,j)-indexes(i,j) -1!!
labuf(st3:st4-1) = abuf(indexes(i,j):indexes_end(i,j)-1) !! labuf(st3:st4-1) = abuf(indexes(i,j):indexes_end(i,j)-1) !!
do k=st3, st4-1
det_minilist(:,:,k) = psi_det_sorted(:,:,labuf(k))
end do
else else
st4 = st3 st4 = st3
end if end if
@ -459,7 +469,7 @@ subroutine alpha_callback_mask(delta_ij_loc, sp, mask, bannedOrb, banned, indexe
call apply_particles(mask, s1, i, s2, j, alpha, ok, N_int) call apply_particles(mask, s1, i, s2, j, alpha, ok, N_int)
!if(.not. ok) stop "non existing alpha......" !if(.not. ok) stop "non existing alpha......"
!print *, "willcall", st4-1, size(labuf) !print *, "willcall", st4-1, size(labuf)
call dress_with_alpha_buffer(delta_ij_loc, labuf, st4-1, alpha, iproc) call dress_with_alpha_buffer(delta_ij_loc, labuf, det_minilist, st4-1, alpha, iproc)
!call dress_with_alpha_buffer(delta_ij_loc, abuf, siz, alpha, 1) !call dress_with_alpha_buffer(delta_ij_loc, abuf, siz, alpha, 1)
end if end if
end do end do
@ -526,17 +536,17 @@ subroutine count_pq(mask, sp, det, i_gen, N_sel, bannedOrb, banned, countedGlob,
negMask(i,2) = not(mask(i,2)) negMask(i,2) = not(mask(i,2))
end do end do
do i=1, N_sel ! interesting(0) do i=1, N_sel
!i = interesting(ii) !if (interesting(i) < 0) then
if (interesting(i) < 0) then ! stop 'prefetch interesting(i)'
stop 'prefetch interesting(i)' !endif
endif
mobMask(1,1) = iand(negMask(1,1), det(1,1,i)) mobMask(1,1) = iand(negMask(1,1), det(1,1,i))
mobMask(1,2) = iand(negMask(1,2), det(1,2,i)) mobMask(1,2) = iand(negMask(1,2), det(1,2,i))
if(interesting(i) < i_gen) cycle
nt = popcnt(mobMask(1, 1)) + popcnt(mobMask(1, 2)) nt = popcnt(mobMask(1, 1)) + popcnt(mobMask(1, 2))
if(nt > 4) cycle if(nt > 4) cycle
do j=2,N_int do j=2,N_int
@ -643,14 +653,14 @@ subroutine splash_pq(mask, sp, det, i_gen, N_sel, bannedOrb, banned, indexes, ab
do i=1, N_sel ! interesting(0) do i=1, N_sel ! interesting(0)
!i = interesting(ii) !i = interesting(ii)
if (interesting(i) < 0) then !if (interesting(i) < 0) then
stop 'prefetch interesting(i)' ! stop 'prefetch interesting(i)'
endif !endif
if(interesting(i) < i_gen) cycle
mobMask(1,1) = iand(negMask(1,1), det(1,1,i)) mobMask(1,1) = iand(negMask(1,1), det(1,1,i))
mobMask(1,2) = iand(negMask(1,2), det(1,2,i)) mobMask(1,2) = iand(negMask(1,2), det(1,2,i))
if(interesting(i) < i_gen) cycle
nt = popcnt(mobMask(1, 1)) + popcnt(mobMask(1, 2)) nt = popcnt(mobMask(1, 1)) + popcnt(mobMask(1, 2))
if(nt > 4) cycle if(nt > 4) cycle

View File

@ -34,7 +34,9 @@ END_PROVIDER
END_DOC END_DOC
END_PROVIDER END_PROVIDER
subroutine dress_with_alpha_buffer(delta_ij_loc, minilist, n_minilist, alpha, iproc)
subroutine dress_with_alpha_buffer(delta_ij_loc, minilist, det_minilist, n_minilist, alpha, iproc)
use bitmasks use bitmasks
implicit none implicit none
BEGIN_DOC BEGIN_DOC
@ -44,7 +46,7 @@ subroutine dress_with_alpha_buffer(delta_ij_loc, minilist, n_minilist, alpha, ip
!n_minilist : size of minilist !n_minilist : size of minilist
!alpha : alpha determinant !alpha : alpha determinant
END_DOC END_DOC
integer(bit_kind), intent(in) :: alpha(N_int,2) integer(bit_kind), intent(in) :: alpha(N_int,2), det_minilist(N_int, 2, n_minilist)
integer,intent(in) :: minilist(n_minilist), n_minilist, iproc integer,intent(in) :: minilist(n_minilist), n_minilist, iproc
double precision, intent(inout) :: delta_ij_loc(N_states,N_det,2) double precision, intent(inout) :: delta_ij_loc(N_states,N_det,2)
@ -63,11 +65,9 @@ subroutine dress_with_alpha_buffer(delta_ij_loc, minilist, n_minilist, alpha, ip
logical :: ok, ok2 logical :: ok, ok2
integer :: old_ninc integer :: old_ninc
double precision :: shdress double precision :: shdress
PROVIDE mo_class PROVIDE mo_class
if(n_minilist == 1) return if(n_minilist == 1) return
do i=1,n_minilist do i=1,n_minilist