mirror of
https://github.com/QuantumPackage/qp2.git
synced 2024-12-22 03:23:29 +01:00
fixed stupid bug in TC 1-RDM and one-e gradient: o-v, o-a are ok
This commit is contained in:
parent
8729a7ca45
commit
b3b080929b
@ -11,8 +11,7 @@
|
|||||||
do t=1,n_act_orb
|
do t=1,n_act_orb
|
||||||
tt=list_act(t)
|
tt=list_act(t)
|
||||||
indx = mat_idx_c_a(i,t)
|
indx = mat_idx_c_a(i,t)
|
||||||
call gradvec_tc_it(ii,tt,res_l)
|
call gradvec_tc_it(ii,tt,res_l,res_r)
|
||||||
call gradvec_tc_it(tt,ii,res_r)
|
|
||||||
do fff = 0,3
|
do fff = 0,3
|
||||||
gradvec_tc_l(fff,indx)=res_l(fff)
|
gradvec_tc_l(fff,indx)=res_l(fff)
|
||||||
gradvec_tc_r(fff,indx)=res_r(fff)
|
gradvec_tc_r(fff,indx)=res_r(fff)
|
||||||
@ -56,23 +55,28 @@ subroutine gradvec_tc_ia(i,a,res)
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
subroutine gradvec_tc_it(i,t,res)
|
subroutine gradvec_tc_it(i,t,res_l, res_r)
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! doubly occupied --> active TC gradient
|
! doubly occupied --> active TC gradient
|
||||||
!
|
!
|
||||||
! Corresponds to <X0|H E_i^t|Phi_0>
|
! Corresponds to res_r = <X0|H E_i^t|Phi_0>
|
||||||
|
!
|
||||||
|
! res_l = <X0|E_i^t H |Phi_0>
|
||||||
END_DOC
|
END_DOC
|
||||||
integer, intent(in) :: i,t
|
integer, intent(in) :: i,t
|
||||||
double precision, intent(out) :: res(0:3)
|
double precision, intent(out) :: res_l(0:3),res_r(0:3)
|
||||||
integer :: rr,r,ss,s
|
integer :: rr,r,ss,s,m
|
||||||
double precision :: dm
|
double precision :: dm
|
||||||
res = 0.d0
|
res_r = 0.d0
|
||||||
res(1) = -2 * mo_bi_ortho_tc_one_e(i,t)
|
do m = 1, mo_num
|
||||||
do rr = 1, n_act_orb
|
res_r(1) += mo_bi_ortho_tc_one_e(i,m) * tc_transition_matrix_mo(t,m,1,1) &
|
||||||
r = list_act(rr)
|
-mo_bi_ortho_tc_one_e(m,t) * tc_transition_matrix_mo(m,i,1,1)
|
||||||
dm = tc_transition_matrix_mo(t,r,1,1)
|
enddo
|
||||||
res(1) += mo_bi_ortho_tc_one_e(i,r) * dm
|
res_l = 0.d0
|
||||||
|
do m = 1, mo_num
|
||||||
|
res_l(1) += mo_bi_ortho_tc_one_e(t,m) * tc_transition_matrix_mo(i,m,1,1) &
|
||||||
|
-mo_bi_ortho_tc_one_e(m,i) * tc_transition_matrix_mo(m,t,1,1)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -25,6 +25,19 @@
|
|||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
do ii = 1, n_core_inact_orb
|
||||||
|
ihole = list_core_inact(ii)
|
||||||
|
do tt = 1, n_act_orb
|
||||||
|
ipart = list_act(tt)
|
||||||
|
indx = mat_idx_c_a(ii,tt)
|
||||||
|
call calc_grad_elem_h_tc(ihole,ipart,res_l, res_r)
|
||||||
|
do ll = 0, 3
|
||||||
|
gradvec_detail_left_old (ll,indx)=res_l(ll)
|
||||||
|
gradvec_detail_right_old(ll,indx)=res_r(ll)
|
||||||
|
enddo
|
||||||
|
enddo
|
||||||
|
enddo
|
||||||
! do indx=1,nMonoEx
|
! do indx=1,nMonoEx
|
||||||
! ihole=excit(1,indx)
|
! ihole=excit(1,indx)
|
||||||
! ipart=excit(2,indx)
|
! ipart=excit(2,indx)
|
||||||
@ -57,7 +70,7 @@ END_PROVIDER
|
|||||||
subroutine calc_grad_elem_h_tc(ihole,ipart,res_l, res_r)
|
subroutine calc_grad_elem_h_tc(ihole,ipart,res_l, res_r)
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! eq 18 of Siegbahn et al, Physica Scripta 1980
|
! eq 18 of Siegbahn et al, Physica Scripta 1980
|
||||||
! we calculate res_l = <Phi| H^tc E_pq | Psi>, and res_r = <Phi| E_qp H^tc | Psi>
|
! we calculate res_r = <Phi| H^tc E_pq | Psi>, and res_r = <Phi| E_qp H^tc | Psi>
|
||||||
! q=hole, p=particle
|
! q=hole, p=particle
|
||||||
! res_l(0) = total matrix element
|
! res_l(0) = total matrix element
|
||||||
! res_l(1) = one-electron part
|
! res_l(1) = one-electron part
|
||||||
@ -89,12 +102,12 @@ subroutine calc_grad_elem_h_tc(ihole,ipart,res_l, res_r)
|
|||||||
if (ierr.eq.1) then
|
if (ierr.eq.1) then
|
||||||
|
|
||||||
call i_H_tc_psi_phi(det_mu_ex,psi_det,psi_l_coef_bi_ortho,psi_r_coef_bi_ortho,N_int &
|
call i_H_tc_psi_phi(det_mu_ex,psi_det,psi_l_coef_bi_ortho,psi_r_coef_bi_ortho,N_int &
|
||||||
,N_det,N_det,N_states,i_H_chi_array,i_H_phi_array)
|
,N_det,psi_det_size,N_states,i_H_chi_array,i_H_phi_array)
|
||||||
! print*,i_H_chi_array(1,1),i_H_phi_array(1,1)
|
! print*,i_H_chi_array(1,1),i_H_phi_array(1,1)
|
||||||
do istate=1,N_states
|
do istate=1,N_states
|
||||||
do ll = 0,3
|
do ll = 0,3
|
||||||
res_l(ll)+=i_H_chi_array(ll,istate)*psi_r_coef_bi_ortho(mu,istate)*phase
|
res_l(ll)+=i_H_phi_array(ll,istate)*psi_l_coef_bi_ortho(mu,istate)*phase
|
||||||
res_r(ll)+=i_H_phi_array(ll,istate)*psi_l_coef_bi_ortho(mu,istate)*phase
|
res_r(ll)+=i_H_chi_array(ll,istate)*psi_r_coef_bi_ortho(mu,istate)*phase
|
||||||
enddo
|
enddo
|
||||||
end do
|
end do
|
||||||
end if
|
end if
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
tc_transition_matrix_mo_alpha(m,m,istate,jstate)+= psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
tc_transition_matrix_mo_alpha(m,m,istate,jstate)+= psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
||||||
enddo
|
enddo
|
||||||
do p = 1, n_occ_ab(2) ! browsing the beta electrons
|
do p = 1, n_occ_ab(2) ! browsing the beta electrons
|
||||||
m = occ(p,1)
|
m = occ(p,2)
|
||||||
tc_transition_matrix_mo_beta(m,m,istate,jstate)+= psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
tc_transition_matrix_mo_beta(m,m,istate,jstate)+= psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
||||||
enddo
|
enddo
|
||||||
else
|
else
|
||||||
@ -38,12 +38,14 @@
|
|||||||
! Single alpha
|
! Single alpha
|
||||||
h = exc(1,1,1) ! hole in psi_det(1,1,j)
|
h = exc(1,1,1) ! hole in psi_det(1,1,j)
|
||||||
p = exc(1,2,1) ! particle in psi_det(1,1,j)
|
p = exc(1,2,1) ! particle in psi_det(1,1,j)
|
||||||
tc_transition_matrix_mo_alpha(p,h,istate,jstate)+= phase * psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
tc_transition_matrix_mo_alpha(p,h,istate,jstate)+= &
|
||||||
|
phase * psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
||||||
else
|
else
|
||||||
! Single beta
|
! Single beta
|
||||||
h = exc(1,1,2) ! hole in psi_det(1,1,j)
|
h = exc(1,1,2) ! hole in psi_det(1,1,j)
|
||||||
p = exc(1,2,2) ! particle in psi_det(1,1,j)
|
p = exc(1,2,2) ! particle in psi_det(1,1,j)
|
||||||
tc_transition_matrix_mo_beta(p,h,istate,jstate)+= phase * psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
tc_transition_matrix_mo_beta(p,h,istate,jstate)+= &
|
||||||
|
phase * psi_l_coef_bi_ortho(i,istate) * psi_r_coef_bi_ortho(j,jstate)
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
Loading…
Reference in New Issue
Block a user