mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-05 11:00:10 +01:00
minor modifs in printing
This commit is contained in:
parent
8a91b293bf
commit
ed1c7eb6f4
@ -5,3 +5,10 @@ interface: ezfio,provider,ocaml
|
|||||||
default: True
|
default: True
|
||||||
|
|
||||||
|
|
||||||
|
[pure_state_specific_mrpt2]
|
||||||
|
type: logical
|
||||||
|
doc: If true, diagonalize the dressed matrix for each state and do a state following of the initial states
|
||||||
|
interface: ezfio,provider,ocaml
|
||||||
|
default: True
|
||||||
|
|
||||||
|
|
||||||
|
@ -10,16 +10,20 @@ end
|
|||||||
|
|
||||||
subroutine routine_3
|
subroutine routine_3
|
||||||
implicit none
|
implicit none
|
||||||
|
integer :: i
|
||||||
!provide fock_virt_total_spin_trace
|
!provide fock_virt_total_spin_trace
|
||||||
provide delta_ij
|
provide delta_ij
|
||||||
|
|
||||||
print *, 'N_det = ', N_det
|
print *, 'N_det = ', N_det
|
||||||
print *, 'N_states = ', N_states
|
print *, 'N_states = ', N_states
|
||||||
print *, 'PT2 = ', second_order_pt_new(1)
|
do i = 1, N_States
|
||||||
print *, 'E = ', CI_energy(1)
|
print*,'State',i
|
||||||
print *, 'E+PT2 = ', CI_energy(1)+second_order_pt_new(1)
|
write(*,'(A12,X,I3,A3,XX,F16.10)') ' PT2 ', i,' = ', second_order_pt_new(i)
|
||||||
print *,'****** DIAGONALIZATION OF DRESSED MATRIX ******'
|
write(*,'(A12,X,I3,A3,XX,F16.09)') ' E ', i,' = ', CI_energy(i)
|
||||||
print *, 'E dressed= ', CI_dressed_pt2_new_energy(1)
|
write(*,'(A12,X,I3,A3,XX,F16.09)') ' E+PT2 ', i,' = ', CI_energy(i)+second_order_pt_new(i)
|
||||||
|
write(*,'(A12,X,I3,A3,XX,F16.09)') ' E dressed ', i,' = ', CI_dressed_pt2_new_energy(i)
|
||||||
|
write(*,'(A12,X,I3,A3,XX,F16.09)') ' S^2 ', i,' = ', CI_dressed_pt2_new_eigenvectors_s2(i)
|
||||||
|
enddo
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -241,13 +241,13 @@ BEGIN_PROVIDER [ double precision, one_anhil_one_creat, (n_act_orb,n_act_orb,2,2
|
|||||||
norm_out,psi_in_out,psi_in_out_coef, n_det,n_det,n_det,N_states)
|
norm_out,psi_in_out,psi_in_out_coef, n_det,n_det,n_det,N_states)
|
||||||
call apply_exc_to_psi(orb_i,hole_particle_i,spin_exc_i, &
|
call apply_exc_to_psi(orb_i,hole_particle_i,spin_exc_i, &
|
||||||
norm_out,psi_in_out,psi_in_out_coef, n_det,n_det,n_det,N_states)
|
norm_out,psi_in_out,psi_in_out_coef, n_det,n_det,n_det,N_states)
|
||||||
if(orb_i == orb_j .and. ispin .ne. jspin)then
|
!if(orb_i == orb_j .and. ispin .ne. jspin)then
|
||||||
call u0_H_dyall_u0_no_exchange(energies,psi_in_out,psi_in_out_coef,n_det,n_det,n_det,N_states,state_target)
|
call u0_H_dyall_u0_no_exchange(energies,psi_in_out,psi_in_out_coef,n_det,n_det,n_det,N_states,state_target)
|
||||||
one_anhil_one_creat(iorb,jorb,ispin,jspin,state_target) = energy_cas_dyall_no_exchange(state_target) - energies(state_target)
|
one_anhil_one_creat(iorb,jorb,ispin,jspin,state_target) = energy_cas_dyall_no_exchange(state_target) - energies(state_target)
|
||||||
else
|
!else
|
||||||
call u0_H_dyall_u0(energies,psi_in_out,psi_in_out_coef,n_det,n_det,n_det,N_states,state_target)
|
! call u0_H_dyall_u0(energies,psi_in_out,psi_in_out_coef,n_det,n_det,n_det,N_states,state_target)
|
||||||
one_anhil_one_creat(iorb,jorb,ispin,jspin,state_target) = energy_cas_dyall(state_target) - energies(state_target)
|
! one_anhil_one_creat(iorb,jorb,ispin,jspin,state_target) = energy_cas_dyall(state_target) - energies(state_target)
|
||||||
endif
|
!endif
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
@ -527,7 +527,7 @@ END_PROVIDER
|
|||||||
|
|
||||||
double precision :: thresh_norm
|
double precision :: thresh_norm
|
||||||
|
|
||||||
thresh_norm = 1.d-10
|
thresh_norm = 1.d-20
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -552,14 +552,7 @@ END_PROVIDER
|
|||||||
call debug_det(psi_in_out,N_int)
|
call debug_det(psi_in_out,N_int)
|
||||||
print*, 'pb, i_ok ne 0 !!!'
|
print*, 'pb, i_ok ne 0 !!!'
|
||||||
endif
|
endif
|
||||||
! call i_H_j_no_k_operators_from_act(psi_in_out(1,1,i),psi_det(1,1,i),N_int,hij_test)
|
|
||||||
call i_H_j(psi_in_out(1,1,i),psi_det(1,1,i),N_int,hij)
|
call i_H_j(psi_in_out(1,1,i),psi_det(1,1,i),N_int,hij)
|
||||||
! if(i==1.and.dabs(hij)>1.d-8)then
|
|
||||||
! if(dabs(hij)>1.d-8)then
|
|
||||||
! print*, ispin,vorb,iorb
|
|
||||||
! print*, i,hij,hij_test
|
|
||||||
! pause
|
|
||||||
! endif
|
|
||||||
do j = 1, n_states
|
do j = 1, n_states
|
||||||
double precision :: coef,contrib
|
double precision :: coef,contrib
|
||||||
coef = psi_coef(i,j) !* psi_coef(i,j)
|
coef = psi_coef(i,j) !* psi_coef(i,j)
|
||||||
@ -635,7 +628,7 @@ BEGIN_PROVIDER [ double precision, one_anhil_inact, (n_inact_orb,n_act_orb,N_Sta
|
|||||||
|
|
||||||
double precision :: thresh_norm
|
double precision :: thresh_norm
|
||||||
|
|
||||||
thresh_norm = 1.d-10
|
thresh_norm = 1.d-20
|
||||||
|
|
||||||
do aorb = 1,n_act_orb
|
do aorb = 1,n_act_orb
|
||||||
orb_a = list_act(aorb)
|
orb_a = list_act(aorb)
|
||||||
|
@ -84,7 +84,11 @@ subroutine mrpt_dress(delta_ij_, Ndet,i_generator,n_selected,det_buffer,Nint,ip
|
|||||||
do i_state = 1, N_states
|
do i_state = 1, N_states
|
||||||
coef_array(i_state) = psi_coef(index_i,i_state)
|
coef_array(i_state) = psi_coef(index_i,i_state)
|
||||||
enddo
|
enddo
|
||||||
call get_delta_e_dyall(psi_det(1,1,index_i),tq(1,1,i_alpha),coef_array,hialpha,delta_e)
|
if(dabs(hialpha).le.1.d-10)then
|
||||||
|
delta_e = 1.d+20
|
||||||
|
else
|
||||||
|
call get_delta_e_dyall(psi_det(1,1,index_i),tq(1,1,i_alpha),coef_array,hialpha,delta_e)
|
||||||
|
endif
|
||||||
hij_array(index_i) = hialpha
|
hij_array(index_i) = hialpha
|
||||||
call get_excitation(psi_det(1,1,index_i),tq(1,1,i_alpha),exc,degree,phase,N_int)
|
call get_excitation(psi_det(1,1,index_i),tq(1,1,i_alpha),exc,degree,phase,N_int)
|
||||||
! phase_array(index_i) = phase
|
! phase_array(index_i) = phase
|
||||||
|
@ -121,8 +121,8 @@
|
|||||||
|
|
||||||
! 1h2p
|
! 1h2p
|
||||||
delta_ij_tmp = 0.d0
|
delta_ij_tmp = 0.d0
|
||||||
!call give_1h2p_contrib(delta_ij_tmp)
|
call give_1h2p_contrib(delta_ij_tmp)
|
||||||
call H_apply_mrpt_1h2p(delta_ij_tmp,N_det)
|
!!!!call H_apply_mrpt_1h2p(delta_ij_tmp,N_det)
|
||||||
accu = 0.d0
|
accu = 0.d0
|
||||||
do i_state = 1, N_states
|
do i_state = 1, N_states
|
||||||
do i = 1, N_det
|
do i = 1, N_det
|
||||||
@ -137,8 +137,8 @@
|
|||||||
|
|
||||||
! 2h1p
|
! 2h1p
|
||||||
delta_ij_tmp = 0.d0
|
delta_ij_tmp = 0.d0
|
||||||
!call give_2h1p_contrib(delta_ij_tmp)
|
call give_2h1p_contrib(delta_ij_tmp)
|
||||||
call H_apply_mrpt_2h1p(delta_ij_tmp,N_det)
|
!!!! call H_apply_mrpt_2h1p(delta_ij_tmp,N_det)
|
||||||
accu = 0.d0
|
accu = 0.d0
|
||||||
do i_state = 1, N_states
|
do i_state = 1, N_states
|
||||||
do i = 1, N_det
|
do i = 1, N_det
|
||||||
@ -152,19 +152,19 @@
|
|||||||
print*, '2h1p = ',accu
|
print*, '2h1p = ',accu
|
||||||
|
|
||||||
! 2h2p
|
! 2h2p
|
||||||
!delta_ij_tmp = 0.d0
|
delta_ij_tmp = 0.d0
|
||||||
!call H_apply_mrpt_2h2p(delta_ij_tmp,N_det)
|
!!!!!call H_apply_mrpt_2h2p(delta_ij_tmp,N_det)
|
||||||
!accu = 0.d0
|
accu = 0.d0
|
||||||
!do i_state = 1, N_states
|
do i_state = 1, N_states
|
||||||
!do i = 1, N_det
|
do i = 1, N_det
|
||||||
! do j = 1, N_det
|
do j = 1, N_det
|
||||||
! accu(i_state) += delta_ij_tmp(j,i,i_state) * psi_coef(i,i_state) * psi_coef(j,i_state)
|
accu(i_state) += delta_ij_tmp(j,i,i_state) * psi_coef(i,i_state) * psi_coef(j,i_state)
|
||||||
! delta_ij(j,i,i_state) += delta_ij_tmp(j,i,i_state)
|
delta_ij(j,i,i_state) += delta_ij_tmp(j,i,i_state)
|
||||||
! enddo
|
enddo
|
||||||
!enddo
|
enddo
|
||||||
!second_order_pt_new_2h2p(i_state) = accu(i_state)
|
second_order_pt_new_2h2p(i_state) = accu(i_state)
|
||||||
!enddo
|
enddo
|
||||||
!print*, '2h2p = ',accu
|
print*, '2h2p = ',accu
|
||||||
|
|
||||||
double precision :: contrib_2h2p(N_states)
|
double precision :: contrib_2h2p(N_states)
|
||||||
call give_2h2p(contrib_2h2p)
|
call give_2h2p(contrib_2h2p)
|
||||||
@ -236,13 +236,15 @@ END_PROVIDER
|
|||||||
logical, allocatable :: good_state_array(:)
|
logical, allocatable :: good_state_array(:)
|
||||||
double precision, allocatable :: s2_values_tmp(:)
|
double precision, allocatable :: s2_values_tmp(:)
|
||||||
integer :: i_other_state
|
integer :: i_other_state
|
||||||
double precision, allocatable :: eigenvectors(:,:), eigenvalues(:)
|
double precision, allocatable :: eigenvectors(:,:), eigenvalues(:), hmatrix_tmp(:,:)
|
||||||
integer :: i_state
|
integer :: i_state
|
||||||
double precision :: s2,e_0
|
double precision :: s2,e_0
|
||||||
integer :: i,j,k
|
integer :: i,j,k
|
||||||
double precision, allocatable :: s2_eigvalues(:)
|
double precision, allocatable :: s2_eigvalues(:)
|
||||||
double precision, allocatable :: e_array(:)
|
double precision, allocatable :: e_array(:)
|
||||||
integer, allocatable :: iorder(:)
|
integer, allocatable :: iorder(:)
|
||||||
|
double precision :: overlap(N_det)
|
||||||
|
double precision, allocatable :: psi_tmp(:)
|
||||||
|
|
||||||
! Guess values for the "N_states_diag" states of the CI_dressed_pt2_new_eigenvectors
|
! Guess values for the "N_states_diag" states of the CI_dressed_pt2_new_eigenvectors
|
||||||
do j=1,min(N_states,N_det)
|
do j=1,min(N_states,N_det)
|
||||||
@ -265,82 +267,131 @@ END_PROVIDER
|
|||||||
else if (diag_algorithm == "Lapack") then
|
else if (diag_algorithm == "Lapack") then
|
||||||
allocate (eigenvectors(N_det,N_det))
|
allocate (eigenvectors(N_det,N_det))
|
||||||
allocate (eigenvalues(N_det))
|
allocate (eigenvalues(N_det))
|
||||||
call lapack_diag(eigenvalues,eigenvectors, &
|
if(pure_state_specific_mrpt2)then
|
||||||
Hmatrix_dressed_pt2_new_symmetrized(1,1,1),N_det,N_det)
|
allocate (hmatrix_tmp(N_det,N_det))
|
||||||
CI_electronic_dressed_pt2_new_energy(:) = 0.d0
|
allocate (iorder(N_det))
|
||||||
if (s2_eig) then
|
allocate (psi_tmp(N_det))
|
||||||
i_state = 0
|
print*,''
|
||||||
allocate (s2_eigvalues(N_det))
|
print*,'***************************'
|
||||||
allocate(index_good_state_array(N_det),good_state_array(N_det))
|
do i_state = 1, N_states !! Big loop over states
|
||||||
good_state_array = .False.
|
print*,''
|
||||||
call u_0_S2_u_0(s2_eigvalues,eigenvectors,N_det,psi_det,N_int,&
|
print*,'Diagonalizing with the dressing for state',i_state
|
||||||
N_det,size(eigenvectors,1))
|
do i = 1, N_det
|
||||||
do j=1,N_det
|
do j = 1, N_det
|
||||||
! Select at least n_states states with S^2 values closed to "expected_s2"
|
hmatrix_tmp(j,i) = Hmatrix_dressed_pt2_new_symmetrized(j,i,i_state)
|
||||||
if(dabs(s2_eigvalues(j)-expected_s2).le.0.5d0)then
|
enddo
|
||||||
i_state += 1
|
|
||||||
index_good_state_array(i_state) = j
|
|
||||||
good_state_array(j) = .True.
|
|
||||||
endif
|
|
||||||
if (i_state==N_states) then
|
|
||||||
exit
|
|
||||||
endif
|
|
||||||
enddo
|
enddo
|
||||||
if (i_state /= 0) then
|
call lapack_diag(eigenvalues,eigenvectors, &
|
||||||
! Fill the first "i_state" states that have a correct S^2 value
|
Hmatrix_dressed_pt2_new_symmetrized(1,1,1),N_det,N_det)
|
||||||
do j = 1, i_state
|
write(*,'(A86)')'Looking for the most overlapping state within all eigenvectors of the dressed matrix'
|
||||||
do i=1,N_det
|
print*,''
|
||||||
CI_dressed_pt2_new_eigenvectors(i,j) = eigenvectors(i,index_good_state_array(j))
|
print*,'Calculating the overlap for ...'
|
||||||
enddo
|
do i = 1, N_det
|
||||||
CI_electronic_dressed_pt2_new_energy(j) = eigenvalues(index_good_state_array(j))
|
overlap(i) = 0.d0
|
||||||
CI_dressed_pt2_new_eigenvectors_s2(j) = s2_eigvalues(index_good_state_array(j))
|
iorder(i) = i
|
||||||
enddo
|
print*,'eigenvector',i
|
||||||
i_other_state = 0
|
do j = 1, N_det
|
||||||
do j = 1, N_det
|
overlap(i)+= psi_coef(j,i_state) * eigenvectors(j,i)
|
||||||
if(good_state_array(j))cycle
|
enddo
|
||||||
i_other_state +=1
|
overlap(i) = -dabs(overlap(i))
|
||||||
if(i_state+i_other_state.gt.n_states_diag)then
|
print*,'energy = ',eigenvalues(i) + nuclear_repulsion
|
||||||
exit
|
print*,'overlap = ',dabs(overlap(i))
|
||||||
endif
|
enddo
|
||||||
do i=1,N_det
|
print*,''
|
||||||
CI_dressed_pt2_new_eigenvectors(i,i_state+i_other_state) = eigenvectors(i,j)
|
print*,'Sorting the eigenvectors per overlap'
|
||||||
enddo
|
call dsort(overlap,iorder,n_states)
|
||||||
CI_electronic_dressed_pt2_new_energy(i_state+i_other_state) = eigenvalues(j)
|
print*,''
|
||||||
CI_dressed_pt2_new_eigenvectors_s2(i_state+i_other_state) = s2_eigvalues(i_state+i_other_state)
|
print*,'The most overlapping state is the ',iorder(1)
|
||||||
enddo
|
print*,'with the overlap of ',dabs(overlap(1))
|
||||||
|
print*,'and an energy of ',eigenvalues(iorder(1)) + nuclear_repulsion
|
||||||
else
|
print*,'Calculating the S^2 value ...'
|
||||||
print*,''
|
do i=1,N_det
|
||||||
print*,'!!!!!!!! WARNING !!!!!!!!!'
|
CI_dressed_pt2_new_eigenvectors(i,i_state) = eigenvectors(i,iorder(1))
|
||||||
print*,' Within the ',N_det,'determinants selected'
|
psi_tmp(i) = eigenvectors(i,iorder(1))
|
||||||
print*,' and the ',N_states_diag,'states requested'
|
enddo
|
||||||
print*,' We did not find any state with S^2 values close to ',expected_s2
|
CI_electronic_dressed_pt2_new_energy(i_state) = eigenvalues(iorder(1))
|
||||||
print*,' We will then set the first N_states eigenvectors of the H matrix'
|
call u_0_S2_u_0(CI_dressed_pt2_new_eigenvectors_s2(i_state),psi_tmp,N_det,psi_det,N_int,1,N_det)
|
||||||
print*,' as the CI_dressed_pt2_new_eigenvectors'
|
print*,'S^2 = ', CI_dressed_pt2_new_eigenvectors_s2(i_state)
|
||||||
print*,' You should consider more states and maybe ask for s2_eig to be .True. or just enlarge the CI space'
|
enddo
|
||||||
print*,''
|
|
||||||
do j=1,min(N_states_diag,N_det)
|
|
||||||
do i=1,N_det
|
|
||||||
CI_dressed_pt2_new_eigenvectors(i,j) = eigenvectors(i,j)
|
|
||||||
enddo
|
|
||||||
CI_electronic_dressed_pt2_new_energy(j) = eigenvalues(j)
|
|
||||||
CI_dressed_pt2_new_eigenvectors_s2(j) = s2_eigvalues(j)
|
|
||||||
enddo
|
|
||||||
endif
|
|
||||||
deallocate(index_good_state_array,good_state_array)
|
|
||||||
deallocate(s2_eigvalues)
|
|
||||||
else
|
else
|
||||||
call u_0_S2_u_0(CI_dressed_pt2_new_eigenvectors_s2,eigenvectors,N_det,psi_det,N_int,&
|
call lapack_diag(eigenvalues,eigenvectors, &
|
||||||
min(N_det,N_states_diag),size(eigenvectors,1))
|
Hmatrix_dressed_pt2_new_symmetrized(1,1,1),N_det,N_det)
|
||||||
! Select the "N_states_diag" states of lowest energy
|
CI_electronic_dressed_pt2_new_energy(:) = 0.d0
|
||||||
do j=1,min(N_det,N_states_diag)
|
if (s2_eig) then
|
||||||
do i=1,N_det
|
i_state = 0
|
||||||
CI_dressed_pt2_new_eigenvectors(i,j) = eigenvectors(i,j)
|
allocate (s2_eigvalues(N_det))
|
||||||
enddo
|
allocate(index_good_state_array(N_det),good_state_array(N_det))
|
||||||
CI_electronic_dressed_pt2_new_energy(j) = eigenvalues(j)
|
good_state_array = .False.
|
||||||
enddo
|
call u_0_S2_u_0(s2_eigvalues,eigenvectors,N_det,psi_det,N_int,&
|
||||||
|
N_det,size(eigenvectors,1))
|
||||||
|
do j=1,N_det
|
||||||
|
! Select at least n_states states with S^2 values closed to "expected_s2"
|
||||||
|
print*, eigenvalues(j)+nuclear_repulsion, s2_eigvalues(j)
|
||||||
|
if(dabs(s2_eigvalues(j)-expected_s2).le.0.5d0)then
|
||||||
|
i_state += 1
|
||||||
|
index_good_state_array(i_state) = j
|
||||||
|
good_state_array(j) = .True.
|
||||||
|
endif
|
||||||
|
if (i_state==N_states) then
|
||||||
|
exit
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
if (i_state /= 0) then
|
||||||
|
! Fill the first "i_state" states that have a correct S^2 value
|
||||||
|
do j = 1, i_state
|
||||||
|
do i=1,N_det
|
||||||
|
CI_dressed_pt2_new_eigenvectors(i,j) = eigenvectors(i,index_good_state_array(j))
|
||||||
|
enddo
|
||||||
|
CI_electronic_dressed_pt2_new_energy(j) = eigenvalues(index_good_state_array(j))
|
||||||
|
CI_dressed_pt2_new_eigenvectors_s2(j) = s2_eigvalues(index_good_state_array(j))
|
||||||
|
enddo
|
||||||
|
i_other_state = 0
|
||||||
|
do j = 1, N_det
|
||||||
|
if(good_state_array(j))cycle
|
||||||
|
i_other_state +=1
|
||||||
|
if(i_state+i_other_state.gt.n_states)then
|
||||||
|
exit
|
||||||
|
endif
|
||||||
|
do i=1,N_det
|
||||||
|
CI_dressed_pt2_new_eigenvectors(i,i_state+i_other_state) = eigenvectors(i,j)
|
||||||
|
enddo
|
||||||
|
CI_electronic_dressed_pt2_new_energy(i_state+i_other_state) = eigenvalues(j)
|
||||||
|
CI_dressed_pt2_new_eigenvectors_s2(i_state+i_other_state) = s2_eigvalues(i_state+i_other_state)
|
||||||
|
enddo
|
||||||
|
|
||||||
|
else
|
||||||
|
print*,''
|
||||||
|
print*,'!!!!!!!! WARNING !!!!!!!!!'
|
||||||
|
print*,' Within the ',N_det,'determinants selected'
|
||||||
|
print*,' and the ',N_states_diag,'states requested'
|
||||||
|
print*,' We did not find any state with S^2 values close to ',expected_s2
|
||||||
|
print*,' We will then set the first N_states eigenvectors of the H matrix'
|
||||||
|
print*,' as the CI_dressed_pt2_new_eigenvectors'
|
||||||
|
print*,' You should consider more states and maybe ask for s2_eig to be .True. or just enlarge the CI space'
|
||||||
|
print*,''
|
||||||
|
do j=1,min(N_states_diag,N_det)
|
||||||
|
do i=1,N_det
|
||||||
|
CI_dressed_pt2_new_eigenvectors(i,j) = eigenvectors(i,j)
|
||||||
|
enddo
|
||||||
|
CI_electronic_dressed_pt2_new_energy(j) = eigenvalues(j)
|
||||||
|
CI_dressed_pt2_new_eigenvectors_s2(j) = s2_eigvalues(j)
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
|
deallocate(index_good_state_array,good_state_array)
|
||||||
|
deallocate(s2_eigvalues)
|
||||||
|
else
|
||||||
|
call u_0_S2_u_0(CI_dressed_pt2_new_eigenvectors_s2,eigenvectors,N_det,psi_det,N_int,&
|
||||||
|
min(N_det,N_states_diag),size(eigenvectors,1))
|
||||||
|
! Select the "N_states_diag" states of lowest energy
|
||||||
|
do j=1,min(N_det,N_states)
|
||||||
|
do i=1,N_det
|
||||||
|
CI_dressed_pt2_new_eigenvectors(i,j) = eigenvectors(i,j)
|
||||||
|
enddo
|
||||||
|
CI_electronic_dressed_pt2_new_energy(j) = eigenvalues(j)
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
|
deallocate(eigenvectors,eigenvalues)
|
||||||
endif
|
endif
|
||||||
deallocate(eigenvectors,eigenvalues)
|
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -361,7 +412,7 @@ BEGIN_PROVIDER [ double precision, CI_dressed_pt2_new_energy, (N_states_diag) ]
|
|||||||
CI_dressed_pt2_new_energy(j) = CI_electronic_dressed_pt2_new_energy(j) + nuclear_repulsion
|
CI_dressed_pt2_new_energy(j) = CI_electronic_dressed_pt2_new_energy(j) + nuclear_repulsion
|
||||||
write(st,'(I4)') j
|
write(st,'(I4)') j
|
||||||
call write_double(output_determinants,CI_dressed_pt2_new_energy(j),'Energy of state '//trim(st))
|
call write_double(output_determinants,CI_dressed_pt2_new_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_dressed_pt2_new_eigenvectors_s2(j) ,'S^2 of state '//trim(st))
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
@ -8,8 +8,10 @@ end
|
|||||||
subroutine routine_2
|
subroutine routine_2
|
||||||
implicit none
|
implicit none
|
||||||
integer :: i,j
|
integer :: i,j
|
||||||
do i =1, n_inact_orb
|
do i =1, n_act_orb
|
||||||
write(*,'(100(F16.10,X))')one_anhil_one_creat_inact_virt(i,:,1)
|
!do i =1, 2
|
||||||
|
write(*,'(I3,x,100(F16.10,X))')i,one_anhil_one_creat(i,:,:,:,1)
|
||||||
|
! write(*,'(I3,x,100(F16.10,X))')i,one_anhil_one_creat(1,4,1,2,1)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
|
||||||
|
@ -1,183 +0,0 @@
|
|||||||
|
|
||||||
|
|
||||||
subroutine i_H_j_no_k_operators_from_act(key_i,key_j,Nint,hij)
|
|
||||||
use bitmasks
|
|
||||||
implicit none
|
|
||||||
BEGIN_DOC
|
|
||||||
! Returns <i|H|j> where i and j are determinants
|
|
||||||
END_DOC
|
|
||||||
integer, intent(in) :: Nint
|
|
||||||
integer(bit_kind), intent(in) :: key_i(Nint,2), key_j(Nint,2)
|
|
||||||
double precision, intent(out) :: hij
|
|
||||||
|
|
||||||
integer :: exc(0:2,2,2)
|
|
||||||
integer :: degree
|
|
||||||
double precision :: get_mo_bielec_integral, phase
|
|
||||||
integer :: m,n,p,q
|
|
||||||
integer :: i,j,k
|
|
||||||
integer :: occ(Nint*bit_kind_size,2)
|
|
||||||
double precision :: diag_H_mat_elem
|
|
||||||
integer :: n_occ_ab(2)
|
|
||||||
logical :: has_mipi(Nint*bit_kind_size)
|
|
||||||
double precision :: mipi(Nint*bit_kind_size), miip(Nint*bit_kind_size), miip_other(Nint*bit_kind_size)
|
|
||||||
PROVIDE mo_bielec_integrals_in_map mo_integrals_map
|
|
||||||
|
|
||||||
ASSERT (Nint > 0)
|
|
||||||
ASSERT (Nint == N_int)
|
|
||||||
ASSERT (sum(popcnt(key_i(:,1))) == elec_alpha_num)
|
|
||||||
ASSERT (sum(popcnt(key_i(:,2))) == elec_beta_num)
|
|
||||||
ASSERT (sum(popcnt(key_j(:,1))) == elec_alpha_num)
|
|
||||||
ASSERT (sum(popcnt(key_j(:,2))) == elec_beta_num)
|
|
||||||
|
|
||||||
hij = 0.d0
|
|
||||||
!DIR$ FORCEINLINE
|
|
||||||
call get_excitation_degree(key_i,key_j,degree,Nint)
|
|
||||||
select case (degree)
|
|
||||||
case (2)
|
|
||||||
call get_double_excitation(key_i,key_j,exc,phase,Nint)
|
|
||||||
if (exc(0,1,1) == 1) then
|
|
||||||
! Mono alpha, mono beta
|
|
||||||
hij = phase*get_mo_bielec_integral( &
|
|
||||||
exc(1,1,1), &
|
|
||||||
exc(1,1,2), &
|
|
||||||
exc(1,2,1), &
|
|
||||||
exc(1,2,2) ,mo_integrals_map)
|
|
||||||
else if (exc(0,1,1) == 2) then
|
|
||||||
! Double alpha
|
|
||||||
hij = phase*(get_mo_bielec_integral( &
|
|
||||||
exc(1,1,1), &
|
|
||||||
exc(2,1,1), &
|
|
||||||
exc(1,2,1), &
|
|
||||||
exc(2,2,1) ,mo_integrals_map) - &
|
|
||||||
get_mo_bielec_integral( &
|
|
||||||
exc(1,1,1), &
|
|
||||||
exc(2,1,1), &
|
|
||||||
exc(2,2,1), &
|
|
||||||
exc(1,2,1) ,mo_integrals_map) )
|
|
||||||
else if (exc(0,1,2) == 2) then
|
|
||||||
! Double beta
|
|
||||||
hij = phase*(get_mo_bielec_integral( &
|
|
||||||
exc(1,1,2), &
|
|
||||||
exc(2,1,2), &
|
|
||||||
exc(1,2,2), &
|
|
||||||
exc(2,2,2) ,mo_integrals_map) - &
|
|
||||||
get_mo_bielec_integral( &
|
|
||||||
exc(1,1,2), &
|
|
||||||
exc(2,1,2), &
|
|
||||||
exc(2,2,2), &
|
|
||||||
exc(1,2,2) ,mo_integrals_map) )
|
|
||||||
endif
|
|
||||||
case (1)
|
|
||||||
call get_mono_excitation(key_i,key_j,exc,phase,Nint)
|
|
||||||
!DIR$ FORCEINLINE
|
|
||||||
call bitstring_to_list_ab(key_i, occ, n_occ_ab, Nint)
|
|
||||||
has_mipi = .False.
|
|
||||||
logical :: is_i_in_active
|
|
||||||
double precision :: accu_a, accu_b, accu_core
|
|
||||||
accu_a = 0.d0
|
|
||||||
accu_b = 0.d0
|
|
||||||
if (exc(0,1,1) == 1) then
|
|
||||||
! Mono alpha
|
|
||||||
m = exc(1,1,1)
|
|
||||||
p = exc(1,2,1)
|
|
||||||
do k = 1, elec_alpha_num
|
|
||||||
i = occ(k,1)
|
|
||||||
if (.not.has_mipi(i)) then
|
|
||||||
mipi(i) = get_mo_bielec_integral(m,i,p,i,mo_integrals_map)
|
|
||||||
has_mipi(i) = .True.
|
|
||||||
endif
|
|
||||||
if(.not.is_i_in_active(i))then
|
|
||||||
miip(i) = get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
else
|
|
||||||
! print*, i,get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
miip(i) = 1.0d0 * get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
accu_a += miip(i)
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
do k = 1, elec_beta_num
|
|
||||||
i = occ(k,2)
|
|
||||||
if (.not.has_mipi(i)) then
|
|
||||||
mipi(i) = get_mo_bielec_integral(m,i,p,i,mo_integrals_map)
|
|
||||||
has_mipi(i) = .True.
|
|
||||||
endif
|
|
||||||
if(.not.is_i_in_active(i))then
|
|
||||||
miip_other(i) = 0.d0
|
|
||||||
else
|
|
||||||
! print*, i,get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
miip_other(i) = 1.0d0 * get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
accu_b += miip(i)
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
! print*, accu_a,accu_b,accu_a + accu_b
|
|
||||||
accu_a = 0.d0
|
|
||||||
accu_b = 0.d0
|
|
||||||
accu_core = mo_mono_elec_integral(m,p)
|
|
||||||
|
|
||||||
do k = 1, elec_alpha_num
|
|
||||||
hij = hij + mipi(occ(k,1)) - miip(occ(k,1))
|
|
||||||
accu_Core += mipi(occ(k,1))
|
|
||||||
if(is_i_in_active(occ(k,1)))then
|
|
||||||
accu_a += miip(occ(k,1))
|
|
||||||
else
|
|
||||||
accu_Core -= miip(occ(k,1))
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
! print*, hij,accu_core
|
|
||||||
do k = 1, elec_beta_num
|
|
||||||
hij = hij + mipi(occ(k,2)) - miip_other(occ(k,2))
|
|
||||||
accu_Core += mipi(occ(k,2))
|
|
||||||
if(is_i_in_active(occ(k,2)))then
|
|
||||||
accu_b += miip_other(occ(k,2))
|
|
||||||
else
|
|
||||||
accu_Core -= miip_other(occ(k,2))
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
! print*, hij,accu_core,accu_core - accu_a - accu_b
|
|
||||||
! print*, accu_a,accu_b,accu_a + accu_b
|
|
||||||
! pause
|
|
||||||
|
|
||||||
else
|
|
||||||
! Mono beta
|
|
||||||
m = exc(1,1,2)
|
|
||||||
p = exc(1,2,2)
|
|
||||||
do k = 1, elec_beta_num
|
|
||||||
i = occ(k,2)
|
|
||||||
if (.not.has_mipi(i)) then
|
|
||||||
mipi(i) = get_mo_bielec_integral(m,i,p,i,mo_integrals_map)
|
|
||||||
has_mipi(i) = .True.
|
|
||||||
endif
|
|
||||||
if(.not.is_i_in_active(i))then
|
|
||||||
miip(i) = get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
else
|
|
||||||
miip(i) = 1.0d0 * get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
do k = 1, elec_alpha_num
|
|
||||||
i = occ(k,1)
|
|
||||||
if (.not.has_mipi(i)) then
|
|
||||||
mipi(i) = get_mo_bielec_integral(m,i,p,i,mo_integrals_map)
|
|
||||||
has_mipi(i) = .True.
|
|
||||||
endif
|
|
||||||
if(.not.is_i_in_active(i))then
|
|
||||||
miip_other(i) = 0.d0
|
|
||||||
else
|
|
||||||
miip_other(i) = 1.0d0 * get_mo_bielec_integral(m,i,i,p,mo_integrals_map)
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
do k = 1, elec_alpha_num
|
|
||||||
hij = hij + mipi(occ(k,1)) - miip_other(occ(k,1))
|
|
||||||
enddo
|
|
||||||
do k = 1, elec_beta_num
|
|
||||||
hij = hij + mipi(occ(k,2)) - miip(occ(k,2))
|
|
||||||
enddo
|
|
||||||
|
|
||||||
endif
|
|
||||||
hij = phase*(hij + mo_mono_elec_integral(m,p))
|
|
||||||
|
|
||||||
case (0)
|
|
||||||
hij = diag_H_mat_elem(key_i,Nint)
|
|
||||||
end select
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -13,21 +13,21 @@ program loc_int
|
|||||||
iorb = list_core_inact(i)
|
iorb = list_core_inact(i)
|
||||||
exchange_int = 0.d0
|
exchange_int = 0.d0
|
||||||
iorder = 0
|
iorder = 0
|
||||||
print*,''
|
|
||||||
if(list_core_inact_check(iorb) == .False.)cycle
|
if(list_core_inact_check(iorb) == .False.)cycle
|
||||||
do j = i+1, n_core_inact_orb
|
do j = i+1, n_core_inact_orb
|
||||||
jorb = list_core_inact(j)
|
jorb = list_core_inact(j)
|
||||||
iorder(jorb) = jorb
|
iorder(jorb) = jorb
|
||||||
exchange_int(jorb) = -mo_bielec_integral_jj_exchange(iorb,jorb)
|
if(list_core_inact_check(jorb) == .False.)then
|
||||||
|
exchange_int(jorb) = 0.d0
|
||||||
|
else
|
||||||
|
exchange_int(jorb) = -mo_bielec_integral_jj_exchange(iorb,jorb)
|
||||||
|
endif
|
||||||
enddo
|
enddo
|
||||||
n_rot += 1
|
n_rot += 1
|
||||||
call dsort(exchange_int,iorder,mo_tot_num)
|
call dsort(exchange_int,iorder,mo_tot_num)
|
||||||
indices(n_rot,1) = iorb
|
indices(n_rot,1) = iorb
|
||||||
indices(n_rot,2) = iorder(1)
|
indices(n_rot,2) = iorder(1)
|
||||||
list_core_inact_check(iorder(1)) = .False.
|
list_core_inact_check(iorder(1)) = .False.
|
||||||
print*,indices(n_rot,1),indices(n_rot,2)
|
|
||||||
print*,''
|
|
||||||
print*,''
|
|
||||||
enddo
|
enddo
|
||||||
print*,'****************************'
|
print*,'****************************'
|
||||||
print*,'-+++++++++++++++++++++++++'
|
print*,'-+++++++++++++++++++++++++'
|
||||||
@ -45,21 +45,21 @@ program loc_int
|
|||||||
iorb = list_act(i)
|
iorb = list_act(i)
|
||||||
exchange_int = 0.d0
|
exchange_int = 0.d0
|
||||||
iorder = 0
|
iorder = 0
|
||||||
print*,''
|
|
||||||
if(list_core_inact_check(iorb) == .False.)cycle
|
if(list_core_inact_check(iorb) == .False.)cycle
|
||||||
do j = i+1, n_act_orb
|
do j = i+1, n_act_orb
|
||||||
jorb = list_act(j)
|
jorb = list_act(j)
|
||||||
iorder(jorb) = jorb
|
iorder(jorb) = jorb
|
||||||
exchange_int(jorb) = -mo_bielec_integral_jj_exchange(iorb,jorb)
|
if(list_core_inact_check(jorb) == .False.)then
|
||||||
|
exchange_int(jorb) = 0.d0
|
||||||
|
else
|
||||||
|
exchange_int(jorb) = -mo_bielec_integral_jj_exchange(iorb,jorb)
|
||||||
|
endif
|
||||||
enddo
|
enddo
|
||||||
n_rot += 1
|
n_rot += 1
|
||||||
call dsort(exchange_int,iorder,mo_tot_num)
|
call dsort(exchange_int,iorder,mo_tot_num)
|
||||||
indices(n_rot,1) = iorb
|
indices(n_rot,1) = iorb
|
||||||
indices(n_rot,2) = iorder(1)
|
indices(n_rot,2) = iorder(1)
|
||||||
list_core_inact_check(iorder(1)) = .False.
|
list_core_inact_check(iorder(1)) = .False.
|
||||||
print*,indices(n_rot,1),indices(n_rot,2)
|
|
||||||
print*,''
|
|
||||||
print*,''
|
|
||||||
enddo
|
enddo
|
||||||
print*,'****************************'
|
print*,'****************************'
|
||||||
print*,'-+++++++++++++++++++++++++'
|
print*,'-+++++++++++++++++++++++++'
|
||||||
@ -82,16 +82,17 @@ program loc_int
|
|||||||
do j = i+1, n_virt_orb
|
do j = i+1, n_virt_orb
|
||||||
jorb = list_virt(j)
|
jorb = list_virt(j)
|
||||||
iorder(jorb) = jorb
|
iorder(jorb) = jorb
|
||||||
exchange_int(jorb) = -mo_bielec_integral_jj_exchange(iorb,jorb)
|
if(list_core_inact_check(jorb) == .False.)then
|
||||||
|
exchange_int(jorb) = 0.d0
|
||||||
|
else
|
||||||
|
exchange_int(jorb) = -mo_bielec_integral_jj_exchange(iorb,jorb)
|
||||||
|
endif
|
||||||
enddo
|
enddo
|
||||||
n_rot += 1
|
n_rot += 1
|
||||||
call dsort(exchange_int,iorder,mo_tot_num)
|
call dsort(exchange_int,iorder,mo_tot_num)
|
||||||
indices(n_rot,1) = iorb
|
indices(n_rot,1) = iorb
|
||||||
indices(n_rot,2) = iorder(1)
|
indices(n_rot,2) = iorder(1)
|
||||||
list_core_inact_check(iorder(1)) = .False.
|
list_core_inact_check(iorder(1)) = .False.
|
||||||
print*,indices(n_rot,1),indices(n_rot,2)
|
|
||||||
print*,''
|
|
||||||
print*,''
|
|
||||||
enddo
|
enddo
|
||||||
print*,'****************************'
|
print*,'****************************'
|
||||||
print*,'-+++++++++++++++++++++++++'
|
print*,'-+++++++++++++++++++++++++'
|
||||||
|
@ -2168,9 +2168,27 @@ subroutine H_u_0_stored(v_0,u_0,hmatrix,sze)
|
|||||||
double precision, intent(in) :: u_0(sze)
|
double precision, intent(in) :: u_0(sze)
|
||||||
v_0 = 0.d0
|
v_0 = 0.d0
|
||||||
call matrix_vector_product(u_0,v_0,hmatrix,sze,sze)
|
call matrix_vector_product(u_0,v_0,hmatrix,sze,sze)
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
subroutine H_s2_u_0_stored(v_0,u_0,hmatrix,s2matrix,sze)
|
||||||
|
use bitmasks
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! Computes v_0 = H|u_0>
|
||||||
|
!
|
||||||
|
! n : number of determinants
|
||||||
|
!
|
||||||
|
! uses the big_matrix_stored array
|
||||||
|
END_DOC
|
||||||
|
integer, intent(in) :: sze
|
||||||
|
double precision, intent(in) :: hmatrix(sze,sze),s2matrix(sze,sze)
|
||||||
|
double precision, intent(out) :: v_0(sze)
|
||||||
|
double precision, intent(in) :: u_0(sze)
|
||||||
|
v_0 = 0.d0
|
||||||
|
call matrix_vector_product(u_0,v_0,hmatrix,sze,sze)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
subroutine u_0_H_u_0_stored(e_0,u_0,hmatrix,sze)
|
subroutine u_0_H_u_0_stored(e_0,u_0,hmatrix,sze)
|
||||||
use bitmasks
|
use bitmasks
|
||||||
implicit none
|
implicit none
|
||||||
|
Loading…
Reference in New Issue
Block a user