10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-10 21:18:29 +01:00

Multistate corrected

This commit is contained in:
Anthony Scemama 2014-05-29 03:40:06 +02:00
parent cbf39830bc
commit ab799d5acb
3 changed files with 33 additions and 15 deletions

View File

@ -177,7 +177,7 @@ class H_apply(object):
call copy_h_apply_buffer_to_wf call copy_h_apply_buffer_to_wf
selection_criterion_min = selection_criterion_min*0.1d0 selection_criterion_min = selection_criterion_min*0.1d0
selection_criterion = selection_criterion_min selection_criterion = selection_criterion_min
call remove_small_contributions !call remove_small_contributions
""" """
self.data["keys_work"] = """ self.data["keys_work"] = """
e_2_pert_buffer = 0.d0 e_2_pert_buffer = 0.d0

View File

@ -11,7 +11,7 @@ program cisd
pt2 = 1.d0 pt2 = 1.d0
diag_algorithm = "Lapack" diag_algorithm = "Lapack"
do while (maxval(abs(pt2(1:N_st))) > 1.d-6) do while (maxval(abs(pt2(1:N_st))) > 1.d-4)
call H_apply_FCI(pt2, norm_pert, H_pert_diag, N_st) call H_apply_FCI(pt2, norm_pert, H_pert_diag, N_st)
call diagonalize_CI call diagonalize_CI
print *, 'N_det = ', N_det print *, 'N_det = ', N_det

View File

@ -33,10 +33,9 @@ subroutine fill_H_apply_buffer_selection(n_selected,det_buffer,e_2_pert_buffer,c
is_selected = .False. is_selected = .False.
do j=1,N_st do j=1,N_st
s = dabs(e_2_pert_buffer(j,i)) s = -e_2_pert_buffer(j,i)
is_selected = s > selection_criterion*selection_criterion_factor .or. is_selected is_selected = s > selection_criterion*selection_criterion_factor .or. is_selected
enddo enddo
ASSERT (s>=-1.d-8)
if (is_selected) then if (is_selected) then
@ -60,8 +59,10 @@ subroutine fill_H_apply_buffer_selection(n_selected,det_buffer,e_2_pert_buffer,c
ASSERT (sum(popcnt(h_apply_buffer(iproc)%det(:,1,i)) )== elec_alpha_num) ASSERT (sum(popcnt(h_apply_buffer(iproc)%det(:,1,i)) )== elec_alpha_num)
ASSERT (sum(popcnt(h_apply_buffer(iproc)%det(:,2,i))) == elec_beta_num) ASSERT (sum(popcnt(h_apply_buffer(iproc)%det(:,2,i))) == elec_beta_num)
enddo enddo
selection_criterion = smax !$OMP CRITICAL
selection_criterion_min = smin selection_criterion = max(selection_criterion,smax)
selection_criterion_min = min(selection_criterion_min,smin)
!$OMP END CRITICAL
end end
BEGIN_PROVIDER [ double precision, selection_criterion ] BEGIN_PROVIDER [ double precision, selection_criterion ]
@ -84,17 +85,32 @@ subroutine remove_small_contributions
! provided. ! provided.
END_DOC END_DOC
integer :: i,j,k, N_removed integer :: i,j,k, N_removed
logical keep logical, allocatable :: keep(:)
double precision :: i_H_psi_array(N_states) double precision :: i_H_psi_array(N_states)
k = 0 allocate (keep(N_det))
N_removed = 0 call diagonalize_CI
do i=N_det, 50 do i=1,N_det
call i_H_psi(psi_det_sorted(1,1,i),psi_det_sorted,psi_coef_sorted,N_int,N_det,psi_det_size,N_states,i_H_psi_array) keep(i) = .True.
keep = .False.
do j=1,N_states
keep = keep .or. (dabs(psi_coef_sorted(i,j)*i_H_psi_array(j)) > selection_criterion_min)
enddo enddo
if (keep) then !$OMP PARALLEL DEFAULT(NONE) &
!$OMP PRIVATE(i,j,i_H_psi_array) &
!$OMP SHARED(k,psi_det_sorted,psi_coef_sorted,N_int,N_det,psi_det_size,N_states, &
!$OMP selection_criterion_min,keep,N_det_generators) &
!$OMP REDUCTION(+:N_removed)
!$OMP DO
do i=2*N_det_generators+1, N_det
call i_H_psi(psi_det_sorted(1,1,i),psi_det_sorted,psi_coef_sorted,N_int,min(N_det,2*N_det_generators),psi_det_size,N_states,i_H_psi_array)
keep(i) = .False.
do j=1,N_states
keep(i) = keep(i) .or. (-(psi_coef_sorted(i,j)*i_H_psi_array(j)) > selection_criterion_min)
enddo
enddo
!$OMP END DO
!$OMP END PARALLEL
N_removed = 0
k = 0
do i=1, N_det
if (keep(i)) then
k += 1 k += 1
do j=1,N_int do j=1,N_int
psi_det(j,1,k) = psi_det_sorted(j,1,i) psi_det(j,1,k) = psi_det_sorted(j,1,i)
@ -107,10 +123,12 @@ subroutine remove_small_contributions
N_removed += 1 N_removed += 1
endif endif
enddo enddo
deallocate(keep)
if (N_removed > 0) then if (N_removed > 0) then
N_det = N_det - N_removed
SOFT_TOUCH N_det psi_det psi_coef
call write_int(output_dets,N_removed, 'Removed determinants') call write_int(output_dets,N_removed, 'Removed determinants')
endif endif
SOFT_TOUCH N_det psi_det psi_coef
end end