mirror of
https://github.com/QuantumPackage/qp2.git
synced 2025-01-05 19:08:47 +01:00
adapted the tc_natorb with block diagonalization
This commit is contained in:
parent
c7dd091b63
commit
1e2f8ab44f
@ -930,11 +930,15 @@ subroutine check_EIGVEC(n, m, A, eigval, leigvec, reigvec, thr_diag, thr_norm, s
|
|||||||
|
|
||||||
tmp_abs = tmp_abs + tmp
|
tmp_abs = tmp_abs + tmp
|
||||||
V_nrm = V_nrm + U_nrm
|
V_nrm = V_nrm + U_nrm
|
||||||
print *, j, tmp, U_nrm
|
write(*,'(I4,X,(100(F25.16,X)))')j,eigval(j), tmp, U_nrm
|
||||||
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
if(tmp_abs.lt.10.d-10)then
|
||||||
|
tmp_rel = thr_diag/10.d0
|
||||||
|
else
|
||||||
tmp_rel = tmp_abs / tmp_nrm
|
tmp_rel = tmp_abs / tmp_nrm
|
||||||
|
endif
|
||||||
tmp_dif = dabs(V_nrm - dble(m))
|
tmp_dif = dabs(V_nrm - dble(m))
|
||||||
|
|
||||||
if( stop_ifnot .and. ((tmp_rel .gt. thr_diag) .or. (tmp_dif .gt. thr_norm)) ) then
|
if( stop_ifnot .and. ((tmp_rel .gt. thr_diag) .or. (tmp_dif .gt. thr_norm)) ) then
|
||||||
@ -969,13 +973,20 @@ subroutine check_EIGVEC(n, m, A, eigval, leigvec, reigvec, thr_diag, thr_norm, s
|
|||||||
|
|
||||||
tmp_abs = tmp_abs + tmp
|
tmp_abs = tmp_abs + tmp
|
||||||
V_nrm = V_nrm + U_nrm
|
V_nrm = V_nrm + U_nrm
|
||||||
print *, j, tmp, U_nrm
|
write(*,'(I4,X,(100(F25.16,X)))')j,eigval(j), tmp, U_nrm
|
||||||
|
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
if(tmp_abs.lt.10.d-10)then
|
||||||
|
tmp_rel = thr_diag/10.d0
|
||||||
|
else
|
||||||
tmp_rel = tmp_abs / tmp_nrm
|
tmp_rel = tmp_abs / tmp_nrm
|
||||||
|
endif
|
||||||
if( stop_ifnot .and. ((tmp_rel .gt. thr_diag) .or. (tmp_dif .gt. thr_norm)) ) then
|
if( stop_ifnot .and. ((tmp_rel .gt. thr_diag) .or. (tmp_dif .gt. thr_norm)) ) then
|
||||||
print *, ' error in left-eigenvectors'
|
print *, ' error in left-eigenvectors'
|
||||||
|
print *, ' err tol = ',thr_diag, thr_norm
|
||||||
|
print *, '(tmp_rel .gt. thr_diag) = ',(tmp_rel .gt. thr_diag)
|
||||||
|
print *, '(tmp_dif .gt. thr_norm) = ',(tmp_dif .gt. thr_norm)
|
||||||
print *, ' err estim = ', tmp_abs, tmp_rel
|
print *, ' err estim = ', tmp_abs, tmp_rel
|
||||||
print *, ' CR norm = ', V_nrm
|
print *, ' CR norm = ', V_nrm
|
||||||
stop
|
stop
|
||||||
|
@ -8,17 +8,23 @@
|
|||||||
! natorb_tc_leigvec_mo : LEFT eigenvectors of the ground state transition matrix (equivalent of natural orbitals)
|
! natorb_tc_leigvec_mo : LEFT eigenvectors of the ground state transition matrix (equivalent of natural orbitals)
|
||||||
! natorb_tc_eigval : eigenvalues of the ground state transition matrix (equivalent of the occupation numbers). WARNINING :: can be negative !!
|
! natorb_tc_eigval : eigenvalues of the ground state transition matrix (equivalent of the occupation numbers). WARNINING :: can be negative !!
|
||||||
END_DOC
|
END_DOC
|
||||||
double precision, allocatable :: dm_tmp(:,:)
|
double precision, allocatable :: dm_tmp(:,:),fock_diag(:)
|
||||||
|
double precision :: thr_deg
|
||||||
integer :: i,j,k,n_real
|
integer :: i,j,k,n_real
|
||||||
allocate( dm_tmp(mo_num,mo_num))
|
allocate( dm_tmp(mo_num,mo_num),fock_diag(mo_num))
|
||||||
dm_tmp(:,:) = -tc_transition_matrix(:,:,1,1)
|
dm_tmp(:,:) = -tc_transition_matrix(:,:,1,1)
|
||||||
print*,'dm_tmp'
|
print*,'dm_tmp'
|
||||||
do i = 1, mo_num
|
do i = 1, mo_num
|
||||||
|
fock_diag(i) = fock_matrix_tc_mo_tot(i,i)
|
||||||
write(*,'(100(F16.10,X))')-dm_tmp(:,i)
|
write(*,'(100(F16.10,X))')-dm_tmp(:,i)
|
||||||
enddo
|
enddo
|
||||||
call non_hrmt_bieig( mo_num, dm_tmp&
|
thr_deg = thr_degen_tc
|
||||||
, natorb_tc_leigvec_mo, natorb_tc_reigvec_mo&
|
call diag_mat_per_fock_degen(fock_diag,dm_tmp,mo_num,thr_deg,&
|
||||||
, n_real, natorb_tc_eigval )
|
natorb_tc_leigvec_mo,natorb_tc_reigvec_mo,&
|
||||||
|
natorb_tc_eigval)
|
||||||
|
! call non_hrmt_bieig( mo_num, dm_tmp&
|
||||||
|
! , natorb_tc_leigvec_mo, natorb_tc_reigvec_mo&
|
||||||
|
! , n_real, natorb_tc_eigval )
|
||||||
double precision :: accu
|
double precision :: accu
|
||||||
accu = 0.d0
|
accu = 0.d0
|
||||||
do i = 1, n_real
|
do i = 1, n_real
|
||||||
|
@ -6,7 +6,7 @@ program print_angles
|
|||||||
! my_n_pt_r_grid = 10 ! small grid for quick debug
|
! my_n_pt_r_grid = 10 ! small grid for quick debug
|
||||||
! my_n_pt_a_grid = 14 ! small grid for quick debug
|
! my_n_pt_a_grid = 14 ! small grid for quick debug
|
||||||
touch my_n_pt_r_grid my_n_pt_a_grid
|
touch my_n_pt_r_grid my_n_pt_a_grid
|
||||||
call sort_by_tc_fock
|
! call sort_by_tc_fock
|
||||||
call minimize_tc_orb_angles
|
call minimize_tc_orb_angles
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -2,3 +2,4 @@ fci
|
|||||||
mo_two_e_erf_ints
|
mo_two_e_erf_ints
|
||||||
aux_quantities
|
aux_quantities
|
||||||
hartree_fock
|
hartree_fock
|
||||||
|
dft_utils_in_r
|
||||||
|
@ -29,10 +29,10 @@ subroutine diag_mat_per_fock_degen(fock_diag,mat_ref,n,thr_deg,leigvec,reigvec,e
|
|||||||
reigvec_unsrtd = 0.d0
|
reigvec_unsrtd = 0.d0
|
||||||
eigval_unsrtd = 0.d0
|
eigval_unsrtd = 0.d0
|
||||||
|
|
||||||
allocate(list_degen(mo_num,0:mo_num))
|
allocate(list_degen(n,0:n))
|
||||||
|
|
||||||
! obtain degeneracies
|
! obtain degeneracies
|
||||||
call give_degen_full_list(fock_diag,mo_num,thr_deg,list_degen,n_degen_list)
|
call give_degen_full_list(fock_diag,n,thr_deg,list_degen,n_degen_list)
|
||||||
allocate(iorder(n_degen_list),list_degen_sorted(n_degen_list))
|
allocate(iorder(n_degen_list),list_degen_sorted(n_degen_list))
|
||||||
do i =1, n_degen_list
|
do i =1, n_degen_list
|
||||||
n_degen = list_degen(i,0)
|
n_degen = list_degen(i,0)
|
||||||
@ -102,9 +102,9 @@ subroutine diag_mat_per_fock_degen(fock_diag,mat_ref,n,thr_deg,leigvec,reigvec,e
|
|||||||
deallocate(mat_tmp,list_same_degen)
|
deallocate(mat_tmp,list_same_degen)
|
||||||
deallocate(eigval_tmp,leigvec_tmp,reigvec_tmp)
|
deallocate(eigval_tmp,leigvec_tmp,reigvec_tmp)
|
||||||
enddo
|
enddo
|
||||||
if(icount.ne.n)then
|
if(icount_eigval.ne.n)then
|
||||||
print*,'pb !! (icount.ne.n)'
|
print*,'pb !! (icount_eigval.ne.n)'
|
||||||
print*,'icount,n',icount,n
|
print*,'icount_eigval,n',icount_eigval,n
|
||||||
stop
|
stop
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user