1
0
mirror of https://gitlab.com/scemama/qp_plugins_scemama.git synced 2025-01-10 13:08:15 +01:00
qp_plugins_scemama/devel/mpn/mpn.irp.f

54 lines
1.3 KiB
FortranFixed
Raw Normal View History

2020-12-23 02:21:15 +01:00
program mpn
implicit none
BEGIN_DOC
! TODO : Put the documentation of the program here
END_DOC
integer :: i, k, l
double precision, allocatable :: c_pert(:,:)
double precision, allocatable :: e_pert(:)
double precision, allocatable :: hc(:), s2(:)
n_states_diag = 1
TOUCH n_states_diag
call generate_fci_space
allocate(c_pert(N_det,0:mp_order))
allocate(s2(N_det))
2020-12-24 00:25:57 +01:00
allocate(e_pert(0:mp_order))
e_pert(0) = energy_det_i(1)
2020-12-23 02:21:15 +01:00
c_pert(:,:) = 0.d0
c_pert(1,0) = 1.d0
2020-12-24 00:25:57 +01:00
e_pert(1) = hf_energy - e_pert(0) - nuclear_repulsion
2020-12-23 02:21:15 +01:00
do k=1,mp_order
! H_ij C^(k-1)
2021-01-04 22:37:55 +01:00
if (distributed_davidson) then
call H_S2_u_0_nstates_zmq (c_pert(1,k),s2,c_pert(1,k-1),1,N_det)
else
call H_S2_u_0_nstates_openmp(c_pert(1,k),s2,c_pert(1,k-1),1,N_det)
endif
2020-12-24 00:25:57 +01:00
if (k>1) then
e_pert(k) += c_pert(1,k)
endif
print *, k, e_pert(k), sum(e_pert) + nuclear_repulsion
2020-12-23 02:21:15 +01:00
c_pert(:,k) = -c_pert(:,k)
2020-12-24 00:25:57 +01:00
c_pert(1,k) = 0.d0
2020-12-23 02:38:34 +01:00
do l=1,k
2020-12-23 02:21:15 +01:00
do i=2,N_det
c_pert(i,k) = c_pert(i,k) + e_pert(l) * c_pert(i,k-l)
enddo
enddo
do i=2,N_det
c_pert(i,k) = c_pert(i,k) + energy_det_i(i) * c_pert(i,k-1)
enddo
do i=2,N_det
c_pert(i,k) = c_pert(i,k) / (energy_det_i(i) - energy_det_i(1))
enddo
enddo
end