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

52 lines
1.0 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-10-25 01:30:30 +02:00
!no_vvvv_integrals = .True.
2019-06-28 16:51:16 +02:00
read_wf = .True.
2019-10-25 01:30:30 +02:00
!touch read_wf no_vvvv_integrals
2019-10-22 18:56:26 +02:00
!call routine
2019-10-25 01:30:30 +02:00
!call routine_bis
call print_grad
end
subroutine print_grad
implicit none
2019-10-25 17:31:09 +02:00
integer :: i
do i = 1, nMonoEx
if(dabs(gradvec2(i)).gt.1.d-5)then
print*,''
print*,i,gradvec2(i),excit(:,i)
endif
enddo
2019-10-22 18:56:26 +02:00
end
2019-06-28 20:45:07 +02:00
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)
2020-03-22 18:18:18 +01:00
accu(1) += state_av_act_2_rdm_spin_trace_mo(ii,jj,kk,ll) * integral
2019-07-04 16:16:57 +02:00
enddo
enddo
enddo
enddo
print*,'accu = ',accu(1)
2019-06-28 16:51:16 +02:00
end