1
0
mirror of https://gitlab.com/scemama/qp_plugins_scemama.git synced 2025-01-05 02:48:42 +01:00

Removed H matrix elements in champ

This commit is contained in:
Anthony Scemama 2020-08-26 10:53:46 +02:00
parent 164bf79053
commit 101012938f

View File

@ -23,73 +23,73 @@ program qmcpack
call system('rm '//trim(ezfio_filename)//'/mo_basis/ao_md5') call system('rm '//trim(ezfio_filename)//'/mo_basis/ao_md5')
call system('$QP_ROOT/src/champ/qp_convert.py '//trim(ezfio_filename)) call system('$QP_ROOT/src/champ/qp_convert.py '//trim(ezfio_filename))
integer :: iunit ! integer :: iunit
integer, external :: getUnitAndOpen ! integer, external :: getUnitAndOpen
iunit = getUnitAndOpen(trim(ezfio_filename)//'.H','w') ! iunit = getUnitAndOpen(trim(ezfio_filename)//'.H','w')
!
double precision, external :: diag_h_mat_elem ! double precision, external :: diag_h_mat_elem
write(iunit,*) N_states ! write(iunit,*) N_states
do istate=1,N_states ! do istate=1,N_states
write(iunit,*) istate, psi_energy_with_nucl_rep(istate) ! write(iunit,*) istate, psi_energy_with_nucl_rep(istate)
enddo ! enddo
write(iunit,*) N_det ! write(iunit,*) N_det
do k=1,N_det ! do k=1,N_det
write(iunit,'(I10,X,F22.15)') k, diag_h_mat_elem(psi_det(1,1,k),N_int) + nuclear_repulsion ! write(iunit,'(I10,X,F22.15)') k, diag_h_mat_elem(psi_det(1,1,k),N_int) + nuclear_repulsion
enddo ! enddo
!
!
double precision :: F(N_states) ! double precision :: F(N_states)
integer(bit_kind), allocatable :: det(:,:,:) ! integer(bit_kind), allocatable :: det(:,:,:)
double precision , allocatable :: coef(:,:) ! double precision , allocatable :: coef(:,:)
integer :: ispin ! integer :: ispin
double precision :: norm(N_states), hij ! double precision :: norm(N_states), hij
allocate(det(N_int,2,N_det), coef(N_det,N_states)) ! allocate(det(N_int,2,N_det), coef(N_det,N_states))
do j=1,mo_num ! do j=1,mo_num
do i=1,j-1 ! do i=1,j-1
do ispin=1,2 ! do ispin=1,2
call build_singly_excited_wavefunction(j,i,1,det,coef) ! call build_singly_excited_wavefunction(j,i,1,det,coef)
F = 0.d0 ! F = 0.d0
do istate=1,N_states ! do istate=1,N_states
norm(istate) = 0.d0 ! norm(istate) = 0.d0
do k=1,N_det ! do k=1,N_det
norm(istate) = norm(istate) + coef(k,istate) * coef(k,istate) ! norm(istate) = norm(istate) + coef(k,istate) * coef(k,istate)
enddo ! enddo
if (norm(istate) > 0.d0) then ! if (norm(istate) > 0.d0) then
norm(istate) = (1.d0/dsqrt(norm(istate))) ! norm(istate) = (1.d0/dsqrt(norm(istate)))
endif ! endif
enddo ! enddo
if (sum(norm(:)) > 0.d0) then ! if (sum(norm(:)) > 0.d0) then
!
do istate = 1,N_states ! do istate = 1,N_states
coef(:,istate) = coef(:,istate) * norm(istate) ! coef(:,istate) = coef(:,istate) * norm(istate)
enddo ! enddo
!$OMP PARALLEL DO DEFAULT(SHARED) PRIVATE(i,j,istate,hij) REDUCTION(+:F) ! !$OMP PARALLEL DO DEFAULT(SHARED) PRIVATE(i,j,istate,hij) REDUCTION(+:F)
do k=1,N_det ! do k=1,N_det
if (sum(coef(k,:)*coef(k,:))==0.d0) cycle ! if (sum(coef(k,:)*coef(k,:))==0.d0) cycle
call i_H_j(det(1,1,k), det(1,1,k), N_int, hij) ! call i_H_j(det(1,1,k), det(1,1,k), N_int, hij)
do istate=1,N_states ! do istate=1,N_states
F(istate) = F(istate) + hij*coef(k,istate)*coef(k,istate) ! F(istate) = F(istate) + hij*coef(k,istate)*coef(k,istate)
enddo ! enddo
do l=1,k-1 ! do l=1,k-1
if (sum(coef(l,:)*coef(l,:))==0.d0) cycle ! if (sum(coef(l,:)*coef(l,:))==0.d0) cycle
call i_H_j(det(1,1,k), det(1,1,l), N_int, hij) ! call i_H_j(det(1,1,k), det(1,1,l), N_int, hij)
do istate=1,N_states ! do istate=1,N_states
F(istate) = F(istate) + 2.d0*hij*coef(k,istate)*coef(l,istate) ! F(istate) = F(istate) + 2.d0*hij*coef(k,istate)*coef(l,istate)
enddo ! enddo
enddo ! enddo
enddo ! enddo
!$OMP END PARALLEL DO ! !$OMP END PARALLEL DO
F(:) = F(:) - psi_energy(:) ! F(:) = F(:) - psi_energy(:)
endif ! endif
do istate=1,N_states ! do istate=1,N_states
write(iunit,'(I4,X,I4,X,I1,X,I3,X,F22.15)') i, j, ispin, istate, F(istate) ! write(iunit,'(I4,X,I4,X,I1,X,I3,X,F22.15)') i, j, ispin, istate, F(istate)
enddo ! enddo
enddo ! enddo
enddo ! enddo
enddo ! enddo
!
deallocate(det,coef) ! deallocate(det,coef)
!
close(iunit) ! close(iunit)
end end