mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-10 13:08:23 +01:00
FIxed Davidson
This commit is contained in:
parent
7f60089223
commit
f75ce67a87
@ -1,7 +1,7 @@
|
|||||||
program fci_zmq
|
program fci_zmq
|
||||||
implicit none
|
implicit none
|
||||||
integer :: i,j,k
|
integer :: i,j,k
|
||||||
logical, external :: detEq
|
logical, external :: detEq
|
||||||
|
|
||||||
double precision, allocatable :: pt2(:)
|
double precision, allocatable :: pt2(:)
|
||||||
integer :: degree
|
integer :: degree
|
||||||
@ -30,10 +30,10 @@ program fci_zmq
|
|||||||
print *, '-----'
|
print *, '-----'
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
double precision :: E_CI_before(N_states)
|
double precision :: E_CI_before(N_states)
|
||||||
|
|
||||||
|
|
||||||
integer :: n_det_before
|
integer :: n_det_before
|
||||||
print*,'Beginning the selection ...'
|
print*,'Beginning the selection ...'
|
||||||
E_CI_before(1:N_states) = CI_energy(1:N_states)
|
E_CI_before(1:N_states) = CI_energy(1:N_states)
|
||||||
|
|
||||||
@ -46,10 +46,10 @@ program fci_zmq
|
|||||||
PROVIDE psi_det_sorted
|
PROVIDE psi_det_sorted
|
||||||
|
|
||||||
if (N_det > N_det_max) then
|
if (N_det > N_det_max) then
|
||||||
psi_det = psi_det_sorted
|
psi_det = psi_det_sorted
|
||||||
psi_coef = psi_coef_sorted
|
psi_coef = psi_coef_sorted
|
||||||
N_det = N_det_max
|
N_det = N_det_max
|
||||||
soft_touch N_det psi_det psi_coef
|
soft_touch N_det psi_det psi_coef
|
||||||
endif
|
endif
|
||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
@ -64,42 +64,44 @@ program fci_zmq
|
|||||||
enddo
|
enddo
|
||||||
print *, '-----'
|
print *, '-----'
|
||||||
if(N_states.gt.1)then
|
if(N_states.gt.1)then
|
||||||
print*,'Variational Energy difference'
|
print*,'Variational Energy difference'
|
||||||
do i = 2, N_states
|
do i = 2, N_states
|
||||||
print*,'Delta E = ',CI_energy(i) - CI_energy(1)
|
print*,'Delta E = ',CI_energy(i) - CI_energy(1)
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
if(N_states.gt.1)then
|
if(N_states.gt.1)then
|
||||||
print*,'Variational + perturbative Energy difference'
|
print*,'Variational + perturbative Energy difference'
|
||||||
do i = 2, N_states
|
do i = 2, N_states
|
||||||
print*,'Delta E = ',E_CI_before(i)+ pt2(i) - (E_CI_before(1) + pt2(1))
|
print*,'Delta E = ',E_CI_before(i)+ pt2(i) - (E_CI_before(1) + pt2(1))
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
E_CI_before(1:N_states) = CI_energy(1:N_states)
|
E_CI_before(1:N_states) = CI_energy(1:N_states)
|
||||||
call ezfio_set_full_ci_energy(CI_energy)
|
call ezfio_set_full_ci_energy(CI_energy)
|
||||||
enddo
|
enddo
|
||||||
N_det = min(N_det_max,N_det)
|
if (N_det > N_det_max) then
|
||||||
touch N_det psi_det psi_coef
|
N_det = N_det_max
|
||||||
call diagonalize_CI
|
touch N_det psi_det psi_coef
|
||||||
if(do_pt2_end)then
|
call diagonalize_CI
|
||||||
print*,'Last iteration only to compute the PT2'
|
endif
|
||||||
threshold_selectors = 1.d0
|
if(do_pt2_end)then
|
||||||
threshold_generators = 0.9999d0
|
print*,'Last iteration only to compute the PT2'
|
||||||
E_CI_before(1:N_states) = CI_energy(1:N_states)
|
threshold_selectors = 1.d0
|
||||||
call ZMQ_selection(1, pt2)
|
threshold_generators = 0.9999d0
|
||||||
print *, 'Final step'
|
E_CI_before(1:N_states) = CI_energy(1:N_states)
|
||||||
print *, 'N_det = ', N_det
|
call ZMQ_selection(1, pt2)
|
||||||
print *, 'N_states = ', N_states
|
print *, 'Final step'
|
||||||
do k=1,N_states
|
print *, 'N_det = ', N_det
|
||||||
print *, 'State', k
|
print *, 'N_states = ', N_states
|
||||||
print *, 'PT2 = ', pt2
|
do k=1,N_states
|
||||||
print *, 'E = ', E_CI_before
|
print *, 'State', k
|
||||||
print *, 'E+PT2 = ', E_CI_before+pt2
|
print *, 'PT2 = ', pt2
|
||||||
print *, '-----'
|
print *, 'E = ', E_CI_before
|
||||||
enddo
|
print *, 'E+PT2 = ', E_CI_before+pt2
|
||||||
call ezfio_set_full_ci_energy_pt2(E_CI_before+pt2)
|
print *, '-----'
|
||||||
endif
|
enddo
|
||||||
call save_wavefunction
|
call ezfio_set_full_ci_energy_pt2(E_CI_before+pt2)
|
||||||
|
endif
|
||||||
|
call save_wavefunction
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ subroutine update_energy(energy)
|
|||||||
! Update energy when it is received from ZMQ
|
! Update energy when it is received from ZMQ
|
||||||
END_DOC
|
END_DOC
|
||||||
integer :: j,k
|
integer :: j,k
|
||||||
do j=1,N_states_diag
|
do j=1,N_states
|
||||||
do k=1,N_det
|
do k=1,N_det
|
||||||
CI_eigenvectors(k,j) = psi_coef(k,j)
|
CI_eigenvectors(k,j) = psi_coef(k,j)
|
||||||
enddo
|
enddo
|
||||||
|
@ -30,6 +30,8 @@ END_PROVIDER
|
|||||||
! Hartree-Fock determinant
|
! Hartree-Fock determinant
|
||||||
END_DOC
|
END_DOC
|
||||||
integer :: i, k
|
integer :: i, k
|
||||||
|
psi_coef_generators = 0.d0
|
||||||
|
psi_det_generators = 0_bit_kind
|
||||||
do i=1,N_det_generators
|
do i=1,N_det_generators
|
||||||
do k=1,N_int
|
do k=1,N_int
|
||||||
psi_det_generators(k,1,i) = psi_det_sorted(k,1,i)
|
psi_det_generators(k,1,i) = psi_det_sorted(k,1,i)
|
||||||
|
@ -8,8 +8,10 @@ BEGIN_PROVIDER [ double precision, CI_energy, (N_states_diag) ]
|
|||||||
integer :: j
|
integer :: j
|
||||||
character*(8) :: st
|
character*(8) :: st
|
||||||
call write_time(output_determinants)
|
call write_time(output_determinants)
|
||||||
do j=1,min(N_det,N_states)
|
do j=1,min(N_det,N_states_diag)
|
||||||
CI_energy(j) = CI_electronic_energy(j) + nuclear_repulsion
|
CI_energy(j) = CI_electronic_energy(j) + nuclear_repulsion
|
||||||
|
enddo
|
||||||
|
do j=1,min(N_det,N_states)
|
||||||
write(st,'(I4)') j
|
write(st,'(I4)') j
|
||||||
call write_double(output_determinants,CI_energy(j),'Energy of state '//trim(st))
|
call write_double(output_determinants,CI_energy(j),'Energy of state '//trim(st))
|
||||||
call write_double(output_determinants,CI_eigenvectors_s2(j),'S^2 of state '//trim(st))
|
call write_double(output_determinants,CI_eigenvectors_s2(j),'S^2 of state '//trim(st))
|
||||||
@ -38,14 +40,14 @@ END_PROVIDER
|
|||||||
double precision, allocatable :: e_array(:)
|
double precision, allocatable :: e_array(:)
|
||||||
integer, allocatable :: iorder(:)
|
integer, allocatable :: iorder(:)
|
||||||
|
|
||||||
! Guess values for the "N_states_diag" states of the CI_eigenvectors
|
! Guess values for the "N_states" states of the CI_eigenvectors
|
||||||
do j=1,min(N_states,N_det)
|
do j=1,min(N_states,N_det)
|
||||||
do i=1,N_det
|
do i=1,N_det
|
||||||
CI_eigenvectors(i,j) = psi_coef(i,j)
|
CI_eigenvectors(i,j) = psi_coef(i,j)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
do j=N_det+1,N_states_diag
|
do j=min(N_states,N_det)+1,N_states_diag
|
||||||
do i=1,N_det
|
do i=1,N_det
|
||||||
CI_eigenvectors(i,j) = 0.d0
|
CI_eigenvectors(i,j) = 0.d0
|
||||||
enddo
|
enddo
|
||||||
@ -143,14 +145,15 @@ END_PROVIDER
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
if( s2_eig.and.(n_states_diag > 1).and.(n_det >= n_states_diag) )then
|
if( s2_eig.and.(N_states_diag > 1).and.(N_det >= N_states_diag) )then
|
||||||
! Diagonalizing S^2 within the "n_states_diag" states found
|
! Diagonalizing S^2 within the "n_states_diag" states found
|
||||||
allocate(s2_eigvalues(N_states_diag), e_array(N_states_diag))
|
allocate(s2_eigvalues(N_states_diag), e_array(N_states_diag))
|
||||||
call diagonalize_s2_betweenstates(psi_det,CI_eigenvectors,n_det,size(psi_det,3),size(CI_eigenvectors,1),min(n_states_diag,n_det),s2_eigvalues)
|
call diagonalize_s2_betweenstates(psi_det,CI_eigenvectors,N_det,size(psi_det,3), &
|
||||||
|
size(CI_eigenvectors,1),min(n_states_diag,n_det),s2_eigvalues)
|
||||||
|
|
||||||
double precision, allocatable :: psi_coef_tmp(:,:)
|
double precision, allocatable :: psi_coef_tmp(:,:)
|
||||||
allocate(psi_coef_tmp(psi_det_size,N_states_diag))
|
allocate(psi_coef_tmp(psi_det_size,N_states_diag))
|
||||||
do j = 1, N_states
|
do j = 1, N_states_diag
|
||||||
do i = 1, N_det
|
do i = 1, N_det
|
||||||
psi_coef_tmp(i,j) = CI_eigenvectors(i,j)
|
psi_coef_tmp(i,j) = CI_eigenvectors(i,j)
|
||||||
enddo
|
enddo
|
||||||
@ -200,11 +203,6 @@ END_PROVIDER
|
|||||||
CI_eigenvectors_s2(i_state + i_other_state) = s2_eigvalues(j)
|
CI_eigenvectors_s2(i_state + i_other_state) = s2_eigvalues(j)
|
||||||
CI_electronic_energy(i_state + i_other_state) = e_array(i_state + i_other_state)
|
CI_electronic_energy(i_state + i_other_state) = e_array(i_state + i_other_state)
|
||||||
enddo
|
enddo
|
||||||
do j=1,N_states
|
|
||||||
do i=1,N_det
|
|
||||||
psi_coef(i,j) = psi_coef_tmp(i,j)
|
|
||||||
enddo
|
|
||||||
enddo
|
|
||||||
deallocate(iorder,e_array,index_good_state_array,good_state_array,psi_coef_tmp)
|
deallocate(iorder,e_array,index_good_state_array,good_state_array,psi_coef_tmp)
|
||||||
|
|
||||||
deallocate(s2_eigvalues)
|
deallocate(s2_eigvalues)
|
||||||
|
@ -12,7 +12,7 @@ BEGIN_PROVIDER [ integer, davidson_sze_max ]
|
|||||||
! Max number of Davidson sizes
|
! Max number of Davidson sizes
|
||||||
END_DOC
|
END_DOC
|
||||||
ASSERT (davidson_sze_max <= davidson_iter_max)
|
ASSERT (davidson_sze_max <= davidson_iter_max)
|
||||||
davidson_sze_max = 8*N_states
|
davidson_sze_max = N_states+7
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user