mirror of
https://github.com/QuantumPackage/qp2.git
synced 2024-11-08 15:13:48 +01:00
61 lines
1.3 KiB
Fortran
61 lines
1.3 KiB
Fortran
|
|
subroutine write_tc_energy()
|
|
|
|
implicit none
|
|
integer :: i, j, k
|
|
double precision :: hmono, htwoe, hthree, htot
|
|
double precision :: E_TC, O_TC
|
|
|
|
do k = 1, n_states
|
|
|
|
E_TC = 0.d0
|
|
do i = 1, N_det
|
|
do j = 1, N_det
|
|
!htot = htilde_matrix_elmt_bi_ortho(i,j)
|
|
call htilde_mu_mat_bi_ortho(psi_det(1,1,i), psi_det(1,1,j), N_int, hmono, htwoe, hthree, htot)
|
|
E_TC = E_TC + psi_l_coef_bi_ortho(i,k) * psi_r_coef_bi_ortho(j,k) * htot
|
|
!E_TC = E_TC + leigvec_tc_bi_orth(i,k) * reigvec_tc_bi_orth(j,k) * htot
|
|
enddo
|
|
enddo
|
|
|
|
O_TC = 0.d0
|
|
do i = 1, N_det
|
|
!O_TC = O_TC + leigvec_tc_bi_orth(i,k) * reigvec_tc_bi_orth(i,k)
|
|
O_TC = O_TC + psi_l_coef_bi_ortho(i,k) * psi_r_coef_bi_ortho(i,k)
|
|
enddo
|
|
|
|
print *, ' state :', k
|
|
print *, " E_TC = ", E_TC / O_TC
|
|
print *, " O_TC = ", O_TC
|
|
|
|
enddo
|
|
|
|
end
|
|
|
|
! ---
|
|
|
|
subroutine write_tc_var()
|
|
|
|
implicit none
|
|
integer :: i, j, k
|
|
double precision :: hmono, htwoe, hthree, htot
|
|
double precision :: SIGMA_TC
|
|
|
|
do k = 1, n_states
|
|
|
|
SIGMA_TC = 0.d0
|
|
do j = 2, N_det
|
|
call htilde_mu_mat_bi_ortho(psi_det(1,1,1), psi_det(1,1,j), N_int, hmono, htwoe, hthree, htot)
|
|
SIGMA_TC = SIGMA_TC + htot * htot
|
|
enddo
|
|
|
|
print *, " state : ", k
|
|
print *, " SIGMA_TC = ", SIGMA_TC
|
|
|
|
enddo
|
|
|
|
end
|
|
|
|
! ---
|
|
|