9
1
mirror of https://github.com/QuantumPackage/qp2.git synced 2025-01-10 12:08:09 +01:00
qp2/src/determinants/energy.irp.f
2020-02-19 14:55:00 -06:00

40 lines
1000 B
Fortran

BEGIN_PROVIDER [ double precision, diagonal_H_matrix_on_psi_det, (N_det) ]
implicit none
BEGIN_DOC
! Diagonal of the Hamiltonian ordered as psi_det
END_DOC
double precision, external :: diag_h_mat_elem
integer :: i
do i=1,N_det
diagonal_H_matrix_on_psi_det(i) = diag_h_mat_elem(psi_det(1,1,i),N_int)
enddo
END_PROVIDER
BEGIN_PROVIDER [ double precision, barycentric_electronic_energy, (N_states) ]
implicit none
BEGIN_DOC
! $E_n = \sum_i {c_i^{(n)}}^2 H_{ii}$
END_DOC
integer :: istate,i
barycentric_electronic_energy(:) = 0.d0
if (is_complex) then
do istate=1,N_states
do i=1,N_det
barycentric_electronic_energy(istate) += cdabs(psi_coef_complex(i,istate)*psi_coef_complex(i,istate))*diagonal_H_matrix_on_psi_det(i)
enddo
enddo
else
do istate=1,N_states
do i=1,N_det
barycentric_electronic_energy(istate) += psi_coef(i,istate)*psi_coef(i,istate)*diagonal_H_matrix_on_psi_det(i)
enddo
enddo
endif
END_PROVIDER