mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-07 03:43:20 +01:00
Davidson OK
This commit is contained in:
parent
bddd875af7
commit
fd6af192b2
@ -710,7 +710,7 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
! =============================
|
! =============================
|
||||||
|
|
||||||
allocate( buffer(N_int,maxab), &
|
allocate( buffer(N_int,maxab), &
|
||||||
singles(singles_alpha_size), &
|
singles(maxab), &
|
||||||
doubles(maxab), &
|
doubles(maxab), &
|
||||||
idx(maxab), &
|
idx(maxab), &
|
||||||
v_t(N_st,N_det), s_t(N_st,N_det), &
|
v_t(N_st,N_det), s_t(N_st,N_det), &
|
||||||
@ -725,7 +725,6 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
|
|
||||||
!$OMP DO SCHEDULE(static,1)
|
!$OMP DO SCHEDULE(static,1)
|
||||||
do k_a=1,N_det
|
do k_a=1,N_det
|
||||||
|
|
||||||
do k=1,singles_alpha(0,krow)
|
do k=1,singles_alpha(0,krow)
|
||||||
is_single_a( singles_alpha(k,krow) ) = .False.
|
is_single_a( singles_alpha(k,krow) ) = .False.
|
||||||
enddo
|
enddo
|
||||||
@ -793,7 +792,6 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
enddo
|
enddo
|
||||||
n_doubles = n_doubles-1
|
n_doubles = n_doubles-1
|
||||||
|
|
||||||
if (n_doubles > 0) then
|
|
||||||
do k=1,n_doubles
|
do k=1,n_doubles
|
||||||
lrow = doubles(k)
|
lrow = doubles(k)
|
||||||
l_a = idx(k)
|
l_a = idx(k)
|
||||||
@ -807,22 +805,9 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
s_t(l,l_a) = s_t(l,l_a) + sij * u_t(l,k_a)
|
s_t(l,l_a) = s_t(l,l_a) + sij * u_t(l,k_a)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
endif
|
|
||||||
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
! Diagonal contribution
|
|
||||||
! ---------------------
|
|
||||||
|
|
||||||
double precision, external :: diag_H_mat_elem, diag_S_mat_elem
|
|
||||||
|
|
||||||
hij = diag_H_mat_elem(tmp_det,N_int)
|
|
||||||
sij = diag_S_mat_elem(tmp_det,N_int)
|
|
||||||
do l=1,N_st
|
|
||||||
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,k_a)
|
|
||||||
s_t(l,k_a) = s_t(l,k_a) + sij * u_t(l,k_a)
|
|
||||||
enddo
|
|
||||||
|
|
||||||
enddo
|
enddo
|
||||||
!$OMP END DO NOWAIT
|
!$OMP END DO NOWAIT
|
||||||
|
|
||||||
@ -855,7 +840,7 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
do while (lcol == kcol)
|
do while (lcol == kcol)
|
||||||
lrow = psi_bilinear_matrix_rows(l_a)
|
lrow = psi_bilinear_matrix_rows(l_a)
|
||||||
buffer(1:N_int,i) = psi_det_alpha_unique(1:N_int, lrow)
|
buffer(1:N_int,i) = psi_det_alpha_unique(1:N_int, lrow)
|
||||||
idx(i) = lrow
|
idx(i) = l_a
|
||||||
i = i +1
|
i = i +1
|
||||||
l_a = l_a+1
|
l_a = l_a+1
|
||||||
if (l_a > N_det) exit
|
if (l_a > N_det) exit
|
||||||
@ -867,17 +852,14 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
buffer, idx, spindet, N_int, i, &
|
buffer, idx, spindet, N_int, i, &
|
||||||
singles, doubles, n_singles, n_doubles )
|
singles, doubles, n_singles, n_doubles )
|
||||||
|
|
||||||
|
|
||||||
! Compute Hij for all alpha singles
|
! Compute Hij for all alpha singles
|
||||||
! ----------------------------------
|
! ----------------------------------
|
||||||
|
|
||||||
l_a = k_a
|
|
||||||
lrow = psi_bilinear_matrix_rows(l_a)
|
|
||||||
tmp_det2(1:N_int,2) = psi_det_beta_unique (1:N_int, kcol)
|
tmp_det2(1:N_int,2) = psi_det_beta_unique (1:N_int, kcol)
|
||||||
do i=1,n_singles
|
do i=1,n_singles
|
||||||
do while ( lrow < singles(i) )
|
l_a = singles(i)
|
||||||
l_a = l_a+1
|
|
||||||
lrow = psi_bilinear_matrix_rows(l_a)
|
lrow = psi_bilinear_matrix_rows(l_a)
|
||||||
enddo
|
|
||||||
tmp_det2(1:N_int,1) = psi_det_alpha_unique(1:N_int, lrow)
|
tmp_det2(1:N_int,1) = psi_det_alpha_unique(1:N_int, lrow)
|
||||||
call i_H_j_mono_spin( tmp_det, tmp_det2, N_int, 1, hij)
|
call i_H_j_mono_spin( tmp_det, tmp_det2, N_int, 1, hij)
|
||||||
do l=1,N_st
|
do l=1,N_st
|
||||||
@ -887,17 +869,14 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
|
||||||
! Compute Hij for all alpha doubles
|
! Compute Hij for all alpha doubles
|
||||||
! ----------------------------------
|
! ----------------------------------
|
||||||
|
|
||||||
l_a = k_a
|
|
||||||
lrow = psi_bilinear_matrix_rows(l_a)
|
|
||||||
do i=1,n_doubles
|
do i=1,n_doubles
|
||||||
do while (lrow < doubles(i))
|
l_a = doubles(i)
|
||||||
l_a = l_a+1
|
|
||||||
lrow = psi_bilinear_matrix_rows(l_a)
|
lrow = psi_bilinear_matrix_rows(l_a)
|
||||||
enddo
|
call i_H_j_double_spin( tmp_det(1,1), psi_det_alpha_unique(1, lrow), N_int, hij)
|
||||||
call i_H_j_double_spin( tmp_det(1,1), psi_det_alpha_unique(1, doubles(i)), N_int, hij)
|
|
||||||
do l=1,N_st
|
do l=1,N_st
|
||||||
v_t(l,l_a) = v_t(l,l_a) + hij * u_t(l,k_a)
|
v_t(l,l_a) = v_t(l,l_a) + hij * u_t(l,k_a)
|
||||||
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,l_a)
|
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,l_a)
|
||||||
@ -920,7 +899,7 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
do while (lrow == krow)
|
do while (lrow == krow)
|
||||||
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
||||||
buffer(1:N_int,i) = psi_det_beta_unique(1:N_int, lcol)
|
buffer(1:N_int,i) = psi_det_beta_unique(1:N_int, lcol)
|
||||||
idx(i) = lcol
|
idx(i) = l_b
|
||||||
i = i +1
|
i = i +1
|
||||||
l_b = l_b+1
|
l_b = l_b+1
|
||||||
if (l_b > N_det) exit
|
if (l_b > N_det) exit
|
||||||
@ -935,17 +914,13 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
! Compute Hij for all beta singles
|
! Compute Hij for all beta singles
|
||||||
! ----------------------------------
|
! ----------------------------------
|
||||||
|
|
||||||
l_b = k_b
|
|
||||||
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
|
||||||
tmp_det2(1:N_int,1) = psi_det_alpha_unique(1:N_int, krow)
|
tmp_det2(1:N_int,1) = psi_det_alpha_unique(1:N_int, krow)
|
||||||
do i=1,n_singles
|
do i=1,n_singles
|
||||||
do while ( lcol < singles(i) )
|
l_b = singles(i)
|
||||||
l_b = l_b+1
|
|
||||||
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
||||||
enddo
|
|
||||||
tmp_det2(1:N_int,2) = psi_det_beta_unique (1:N_int, lcol)
|
tmp_det2(1:N_int,2) = psi_det_beta_unique (1:N_int, lcol)
|
||||||
l_a = psi_bilinear_matrix_transp_order(l_b)
|
|
||||||
call i_H_j_mono_spin( tmp_det, tmp_det2, N_int, 2, hij)
|
call i_H_j_mono_spin( tmp_det, tmp_det2, N_int, 2, hij)
|
||||||
|
l_a = psi_bilinear_matrix_transp_order(l_b)
|
||||||
do l=1,N_st
|
do l=1,N_st
|
||||||
v_t(l,l_a) = v_t(l,l_a) + hij * u_t(l,k_a)
|
v_t(l,l_a) = v_t(l,l_a) + hij * u_t(l,k_a)
|
||||||
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,l_a)
|
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,l_a)
|
||||||
@ -956,15 +931,11 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
! Compute Hij for all beta doubles
|
! Compute Hij for all beta doubles
|
||||||
! ----------------------------------
|
! ----------------------------------
|
||||||
|
|
||||||
l_b = k_b
|
|
||||||
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
|
||||||
do i=1,n_doubles
|
do i=1,n_doubles
|
||||||
do while (lcol < doubles(i))
|
l_b = doubles(i)
|
||||||
l_b = l_b+1
|
|
||||||
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
lcol = psi_bilinear_matrix_transp_columns(l_b)
|
||||||
enddo
|
call i_H_j_double_spin( tmp_det(1,2), psi_det_beta_unique(1, lcol), N_int, hij)
|
||||||
l_a = psi_bilinear_matrix_transp_order(l_b)
|
l_a = psi_bilinear_matrix_transp_order(l_b)
|
||||||
call i_H_j_double_spin( tmp_det(1,2), psi_det_beta_unique(1, doubles(i)), N_int, hij)
|
|
||||||
do l=1,N_st
|
do l=1,N_st
|
||||||
v_t(l,l_a) = v_t(l,l_a) + hij * u_t(l,k_a)
|
v_t(l,l_a) = v_t(l,l_a) + hij * u_t(l,k_a)
|
||||||
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,l_a)
|
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,l_a)
|
||||||
@ -972,8 +943,20 @@ subroutine H_S2_u_0_nstates_bilinear_order(v_0,s_0,u_0,N_st,sze_8)
|
|||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
! Diagonal contribution
|
||||||
|
! ---------------------
|
||||||
|
|
||||||
|
double precision, external :: diag_H_mat_elem, diag_S_mat_elem
|
||||||
|
|
||||||
|
hij = diag_H_mat_elem(tmp_det,N_int)
|
||||||
|
sij = diag_S_mat_elem(tmp_det,N_int)
|
||||||
|
do l=1,N_st
|
||||||
|
v_t(l,k_a) = v_t(l,k_a) + hij * u_t(l,k_a)
|
||||||
|
s_t(l,k_a) = s_t(l,k_a) + sij * u_t(l,k_a)
|
||||||
enddo
|
enddo
|
||||||
!$OMP END DO NOWAIT
|
|
||||||
|
end do
|
||||||
|
!$OMP END DO
|
||||||
|
|
||||||
!$OMP CRITICAL
|
!$OMP CRITICAL
|
||||||
do l=1,N_st
|
do l=1,N_st
|
||||||
@ -1021,6 +1004,11 @@ subroutine H_S2_u_0_nstates_test(v_0,s_0,u_0,H_jj,S2_jj,n,keys_tmp,Nint,N_st,sze
|
|||||||
integer :: degree
|
integer :: degree
|
||||||
integer :: exc(0:2,2,2)
|
integer :: exc(0:2,2,2)
|
||||||
call get_excitation(keys_tmp(1,1,j),keys_tmp(1,1,i),exc,degree,phase,Nint)
|
call get_excitation(keys_tmp(1,1,j),keys_tmp(1,1,i),exc,degree,phase,Nint)
|
||||||
|
! if ((degree == 2).and.(exc(0,1,1)==1)) then
|
||||||
|
! continue
|
||||||
|
! else
|
||||||
|
! cycle
|
||||||
|
! endif
|
||||||
! if ((degree == 2).and.(exc(0,1,1)==1)) cycle
|
! if ((degree == 2).and.(exc(0,1,1)==1)) cycle
|
||||||
! if ((degree > 1)) cycle
|
! if ((degree > 1)) cycle
|
||||||
! if (exc(0,1,2) /= 0) cycle
|
! if (exc(0,1,2) /= 0) cycle
|
||||||
|
@ -2524,7 +2524,7 @@ subroutine i_H_j_mono_spin(key_i,key_j,Nint,spin,hij)
|
|||||||
PROVIDE big_array_exchange_integrals mo_bielec_integrals_in_map
|
PROVIDE big_array_exchange_integrals mo_bielec_integrals_in_map
|
||||||
|
|
||||||
call get_mono_excitation_spin(key_i(1,spin),key_j(1,spin),exc,phase,Nint)
|
call get_mono_excitation_spin(key_i(1,spin),key_j(1,spin),exc,phase,Nint)
|
||||||
call get_mono_excitation_from_fock(key_i,key_j,exc(1,2),exc(1,1),spin,phase,hij)
|
call get_mono_excitation_from_fock(key_i,key_j,exc(1,1),exc(1,2),spin,phase,hij)
|
||||||
end
|
end
|
||||||
|
|
||||||
subroutine i_H_j_double_spin(key_i,key_j,Nint,hij)
|
subroutine i_H_j_double_spin(key_i,key_j,Nint,hij)
|
||||||
|
@ -641,17 +641,17 @@ subroutine get_all_spin_singles_and_doubles(buffer, idx, spindet, Nint, size_buf
|
|||||||
|
|
||||||
!DIR$ ATTRIBUTES ALIGN : $IRP_ALIGN :: xorvec, degree
|
!DIR$ ATTRIBUTES ALIGN : $IRP_ALIGN :: xorvec, degree
|
||||||
|
|
||||||
select case (Nint)
|
! select case (Nint)
|
||||||
case (1)
|
! case (1)
|
||||||
call get_all_spin_singles_and_doubles_1(buffer, idx, spindet(1), size_buffer, singles, doubles, n_singles, n_doubles)
|
! call get_all_spin_singles_and_doubles_1(buffer, idx, spindet(1), size_buffer, singles, doubles, n_singles, n_doubles)
|
||||||
return
|
! return
|
||||||
! case (2)
|
! case (2)
|
||||||
! call get_all_spin_singles_and_doubles_2(buffer, idx, spindet, size_buffer, singles, doubles, n_singles, n_doubles)
|
! call get_all_spin_singles_and_doubles_2(buffer, idx, spindet, size_buffer, singles, doubles, n_singles, n_doubles)
|
||||||
! return
|
! return
|
||||||
case (3)
|
! case (3)
|
||||||
call get_all_spin_singles_and_doubles_3(buffer, idx, spindet, size_buffer, singles, doubles, n_singles, n_doubles)
|
! call get_all_spin_singles_and_doubles_3(buffer, idx, spindet, size_buffer, singles, doubles, n_singles, n_doubles)
|
||||||
return
|
! return
|
||||||
end select
|
! end select
|
||||||
|
|
||||||
|
|
||||||
size_buffer_align = align_double(size_buffer)
|
size_buffer_align = align_double(size_buffer)
|
||||||
|
Loading…
Reference in New Issue
Block a user