10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-10 04:58:25 +01:00

Updated FCI

This commit is contained in:
Anthony Scemama 2014-05-29 01:38:46 +02:00
parent 1ba8f49949
commit 0dc90dbde8
7 changed files with 86 additions and 28 deletions

View File

@ -346,16 +346,16 @@ subroutine $subroutine($params_main)
integer :: i_generator, k integer :: i_generator, k
do i_generator=1,N_det_generators do i_generator=1,N_det_generators
call $subroutine_monoexc(psi_generators(1,1,i_generator), &
generators_bitmask(1,1,s_hole ,i_bitmask_gen), &
generators_bitmask(1,1,s_part ,i_bitmask_gen), &
i_generator $params_post)
call $subroutine_diexc(psi_generators(1,1,i_generator), & call $subroutine_diexc(psi_generators(1,1,i_generator), &
generators_bitmask(1,1,d_hole1,i_bitmask_gen), & generators_bitmask(1,1,d_hole1,i_bitmask_gen), &
generators_bitmask(1,1,d_part1,i_bitmask_gen), & generators_bitmask(1,1,d_part1,i_bitmask_gen), &
generators_bitmask(1,1,d_hole2,i_bitmask_gen), & generators_bitmask(1,1,d_hole2,i_bitmask_gen), &
generators_bitmask(1,1,d_part2,i_bitmask_gen), & generators_bitmask(1,1,d_part2,i_bitmask_gen), &
i_generator $params_post) i_generator $params_post)
call $subroutine_monoexc(psi_generators(1,1,i_generator), &
generators_bitmask(1,1,s_hole ,i_bitmask_gen), &
generators_bitmask(1,1,s_part ,i_bitmask_gen), &
i_generator $params_post)
if (abort_here) then if (abort_here) then
exit exit
endif endif

View File

@ -374,8 +374,8 @@ end
BEGIN_DOC BEGIN_DOC
! Can be : [ energy | residual | both | wall_time | cpu_time | iterations ] ! Can be : [ energy | residual | both | wall_time | cpu_time | iterations ]
END_DOC END_DOC
davidson_criterion = 'both' davidson_criterion = 'residual'
davidson_threshold = 1.d-8 davidson_threshold = 1.d-6
END_PROVIDER END_PROVIDER
subroutine davidson_converged(energy,residual,wall,iterations,cpu,N_st,converged) subroutine davidson_converged(energy,residual,wall,iterations,cpu,N_st,converged)

View File

@ -80,3 +80,54 @@ BEGIN_PROVIDER [ integer, N_det_reference ]
N_det_reference = N_det N_det_reference = N_det
ASSERT (N_det_reference > 0) ASSERT (N_det_reference > 0)
END_PROVIDER END_PROVIDER
BEGIN_PROVIDER [ double precision, psi_average_norm_contrib, (N_det) ]
implicit none
BEGIN_DOC
! Contribution of determinants to the state-averaged density
END_DOC
integer :: i,j,k
double precision :: f
f = 1.d0/dble(N_states)
do i=1,N_det
psi_average_norm_contrib(i) = psi_coef(i,1)*psi_coef(i,1)*f
enddo
do k=2,N_states
do i=1,N_det
psi_average_norm_contrib(i) = psi_average_norm_contrib(i) + &
psi_coef(i,k)*psi_coef(i,k)*f
enddo
enddo
END_PROVIDER
BEGIN_PROVIDER [ integer(bit_kind), psi_det_sorted, (N_int,2,N_det) ]
&BEGIN_PROVIDER [ double precision, psi_coef_sorted, (N_det,N_states) ]
&BEGIN_PROVIDER [ double precision, psi_average_norm_contrib_sorted, (N_det) ]
implicit none
BEGIN_DOC
! Wave function sorted by determinants (state-averaged)
END_DOC
integer :: i,j,k
integer, allocatable :: iorder(:)
allocate ( iorder(N_det) )
do i=1,N_det
psi_average_norm_contrib_sorted(i) = -psi_average_norm_contrib(i)
iorder(i) = i
enddo
call dsort(psi_average_norm_contrib_sorted,iorder,N_det)
!DIR$ IVDEP
do i=1,N_det
do j=1,N_int
psi_det_sorted(j,1,i) = psi_det(j,1,iorder(i))
psi_det_sorted(j,2,i) = psi_det(j,2,iorder(i))
enddo
do k=1,N_states
psi_coef_sorted(i,k) = psi_coef(iorder(i),k)
enddo
psi_average_norm_contrib_sorted(i) = -psi_average_norm_contrib_sorted(i)
enddo
deallocate(iorder)
END_PROVIDER

View File

@ -22,8 +22,12 @@ BEGIN_PROVIDER [ double precision, CI_energy, (N_states) ]
END_DOC END_DOC
integer :: j integer :: j
character*(8) :: st
call write_time(output_Dets)
do j=1,N_states do j=1,N_states
CI_energy(j) = CI_electronic_energy(j) + nuclear_repulsion CI_energy(j) = CI_electronic_energy(j) + nuclear_repulsion
write(st,'(I4)') j
call write_double(output_Dets,CI_energy(j),'Energy of state '//trim(st))
enddo enddo
END_PROVIDER END_PROVIDER

View File

@ -10,6 +10,9 @@ Documentation
.. Do not edit this section. It was auto-generated from the .. Do not edit this section. It was auto-generated from the
.. NEEDED_MODULES file. .. NEEDED_MODULES file.
`cisd <http://github.com/LCPQ/quantum_package/tree/master/src/Full_CI/full_ci.irp.f#L1>`_
Undocumented
Needed Modules Needed Modules

View File

@ -3,18 +3,15 @@ program cisd
integer :: i,k integer :: i,k
double precision, allocatable :: pt2(:), norm_pert(:) double precision, allocatable :: pt2(:), norm_pert(:), H_pert_diag(:)
double precision :: H_pert_diag, E_old
integer :: N_st, degree integer :: N_st, degree
character*(64) :: perturbation character*(64) :: perturbation
N_st = N_states N_st = N_states
allocate (pt2(N_st), norm_pert(N_st)) allocate (pt2(N_st), norm_pert(N_st),H_pert_diag(N_st))
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-6)
print *, '-----'
E_old = CI_energy(1)
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
@ -22,6 +19,7 @@ program cisd
print *, 'PT2 = ', pt2 print *, 'PT2 = ', pt2
print *, 'E = ', CI_energy print *, 'E = ', CI_energy
print *, 'E+PT2 = ', CI_energy+pt2 print *, 'E+PT2 = ', CI_energy+pt2
print *, '-----'
if (abort_all) then if (abort_all) then
exit exit
endif endif

View File

@ -31,13 +31,13 @@ subroutine fill_H_apply_buffer_selection(n_selected,det_buffer,e_2_pert_buffer,c
l=H_apply_buffer(iproc)%N_det l=H_apply_buffer(iproc)%N_det
do i=1,n_selected do i=1,n_selected
s = 0.d0 is_selected = .False.
do j=1,N_st do j=1,N_st
s -= e_2_pert_buffer(j,i) s = dabs(e_2_pert_buffer(j,i))
is_selected = s > selection_criterion*selection_criterion_factor .or. is_selected
enddo enddo
ASSERT (s>=-1.d-8) ASSERT (s>=-1.d-8)
is_selected = s > selection_criterion * selection_criterion_factor
if (is_selected) then if (is_selected) then
l = l+1 l = l+1
@ -71,7 +71,7 @@ end
BEGIN_DOC BEGIN_DOC
! Threshold to select determinants. Set by selection routines. ! Threshold to select determinants. Set by selection routines.
END_DOC END_DOC
selection_criterion = .1d0 selection_criterion = 1.d0
selection_criterion_factor = 0.01d0 selection_criterion_factor = 0.01d0
selection_criterion_min = selection_criterion selection_criterion_min = selection_criterion
@ -80,35 +80,37 @@ END_PROVIDER
subroutine remove_small_contributions subroutine remove_small_contributions
implicit none implicit none
BEGIN_DOC BEGIN_DOC
! Remove determinants with small contributions ! Remove determinants with small contributions. N_states is assumed to be
! provided.
END_DOC END_DOC
integer :: i,j,k, N_removed integer :: i,j,k, N_removed
logical keep logical keep
double precision :: i_H_psi_array(N_states)
k = 0
N_removed = 0 N_removed = 0
do i=N_det,1,-1 do i=N_det, 50
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 = .False. keep = .False.
do j=1,N_states do j=1,N_states
keep = keep .or. (dabs(psi_coef(i,j)) > selection_criterion_min) keep = keep .or. (dabs(psi_coef_sorted(i,j)*i_H_psi_array(j)) > selection_criterion_min)
enddo enddo
if (.not.keep) then if (keep) then
do k=i+1,N_det k += 1
do j=1,N_int do j=1,N_int
psi_det(j,1,k-1) = psi_det(j,1,k) psi_det(j,1,k) = psi_det_sorted(j,1,i)
psi_det(j,2,k-1) = psi_det(j,2,k) psi_det(j,2,k) = psi_det_sorted(j,2,i)
enddo
enddo enddo
do j=1,N_states do j=1,N_states
do k=i+1,N_det psi_coef(k,j) = psi_coef_sorted(i,j)
psi_coef(k-1,j) = psi_coef(k,j)
enddo
enddo enddo
else
N_removed += 1 N_removed += 1
endif endif
enddo enddo
if (N_removed > 0) then if (N_removed > 0) then
N_det -= N_removed
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