9
1
mirror of https://github.com/QuantumPackage/qp2.git synced 2024-11-08 14:33:38 +01:00
qp2/src/casscf/get_energy.irp.f

83 lines
1.8 KiB
Fortran
Raw Normal View History

2019-06-28 16:51:16 +02:00
program print_2rdm
implicit none
2019-06-29 17:29:32 +02:00
BEGIN_DOC
! get the active part of the bielectronic energy on a given wave function.
!
! useful to test the active part of the spin trace 2 rdms
END_DOC
2019-07-05 18:50:22 +02:00
no_vvvv_integrals = .True.
2019-06-28 16:51:16 +02:00
read_wf = .True.
2019-07-05 18:50:22 +02:00
touch read_wf no_vvvv_integrals
2019-10-22 18:56:26 +02:00
!call routine
call routine_bis
end
subroutine routine_bis
implicit none
integer :: i,j
double precision :: accu_d,accu_od
accu_d = 0.d0
accu_od = 0.d0
print*,''
print*,''
print*,''
do i = 1, mo_num
write(*,'(100(F8.5,X))')super_ci_dm(i,:)
accu_d += super_ci_dm(i,i)
do j = i+1, mo_num
accu_od += dabs(super_ci_dm(i,j) - super_ci_dm(j,i))
enddo
enddo
print*,''
print*,''
print*,'accu_d = ',accu_d
print*,'n_elec = ',elec_num
print*,'accu_od= ',accu_od
print*,''
2019-06-28 20:45:07 +02:00
end
subroutine routine
2019-06-28 16:51:16 +02:00
integer :: i,j,k,l
2019-06-28 20:45:07 +02:00
integer :: ii,jj,kk,ll
2019-06-28 16:51:16 +02:00
double precision :: accu(4),twodm,thr,act_twodm2,integral,get_two_e_integral
thr = 1.d-10
2019-06-28 20:45:07 +02:00
2019-06-28 16:51:16 +02:00
accu = 0.d0
2019-06-28 20:45:07 +02:00
do ll = 1, n_act_orb
l = list_act(ll)
do kk = 1, n_act_orb
k = list_act(kk)
do jj = 1, n_act_orb
j = list_act(jj)
do ii = 1, n_act_orb
i = list_act(ii)
2019-06-28 16:51:16 +02:00
integral = get_two_e_integral(i,j,k,l,mo_integrals_map)
accu(1) += state_av_act_two_rdm_spin_trace_mo(ii,jj,kk,ll) * integral
2019-06-28 16:51:16 +02:00
enddo
enddo
enddo
enddo
2019-06-28 20:45:07 +02:00
print*,'accu = ',accu(1)
2019-07-04 16:16:57 +02:00
accu = 0.d0
do ll = 1, n_act_orb
l = list_act(ll)
do kk = 1, n_act_orb
k = list_act(kk)
do jj = 1, n_act_orb
j = list_act(jj)
do ii = 1, n_act_orb
i = list_act(ii)
integral = get_two_e_integral(i,j,k,l,mo_integrals_map)
accu(1) += state_av_act_two_rdm_openmp_spin_trace_mo(ii,jj,kk,ll) * integral
enddo
enddo
enddo
enddo
print*,'accu = ',accu(1)
print*,'psi_energy_two_e = ',psi_energy_two_e
2019-07-05 18:50:22 +02:00
print *, psi_energy_with_nucl_rep
2019-06-28 16:51:16 +02:00
end