mirror of
https://github.com/QuantumPackage/qp2.git
synced 2025-01-08 19:32:58 +01:00
Doublet also works. Running tests.
This commit is contained in:
parent
4583fa80b0
commit
409aa82373
@ -761,7 +761,10 @@ end subroutine get_phase_qp_to_cfg
|
|||||||
! 4. DOMO -> SOMO
|
! 4. DOMO -> SOMO
|
||||||
!print *,"Doing DOMO -> SOMO"
|
!print *,"Doing DOMO -> SOMO"
|
||||||
!AIJpqContainer(NSOMOMin,4,1,1,1,1) = 1.0d0
|
!AIJpqContainer(NSOMOMin,4,1,1,1,1) = 1.0d0
|
||||||
AIJpqContainer(1,1,1:2,1:2,4,NSOMOMin) = 1.0d0
|
AIJpqContainer(1,1,1,1,4,NSOMOMin) = 1.0d0
|
||||||
|
AIJpqContainer(1,1,2,2,4,NSOMOMin) = 1.0d0
|
||||||
|
AIJpqContainer(1,1,2,1,4,NSOMOMin) =-1.0d0
|
||||||
|
AIJpqContainer(1,1,1,2,4,NSOMOMin) =-1.0d0
|
||||||
do i = NSOMOMin+2, NSOMOMax, 2
|
do i = NSOMOMin+2, NSOMOMax, 2
|
||||||
Isomo = ISHFT(1_8,i)-1
|
Isomo = ISHFT(1_8,i)-1
|
||||||
do j = i,i, 2
|
do j = i,i, 2
|
||||||
@ -779,6 +782,10 @@ end subroutine get_phase_qp_to_cfg
|
|||||||
Jsomo = ISHFT(1_8,j)-1
|
Jsomo = ISHFT(1_8,j)-1
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
!print *,"k,l=",k,l
|
||||||
|
!call debug_spindet(Jsomo,1)
|
||||||
|
!call debug_spindet(Isomo,1)
|
||||||
|
|
||||||
!AIJpqContainer(i,4,k,l,:,:) = 0.0d0
|
!AIJpqContainer(i,4,k,l,:,:) = 0.0d0
|
||||||
AIJpqContainer(:,:,k,l,4,i) = 0.0d0
|
AIJpqContainer(:,:,k,l,4,i) = 0.0d0
|
||||||
call getApqIJMatrixDims(Isomo, &
|
call getApqIJMatrixDims(Isomo, &
|
||||||
|
@ -324,7 +324,8 @@ subroutine davidson_diag_cfg_hjj(dets_in,u_in,H_jj,energies,dim_in,sze,sze_csf,N
|
|||||||
tmpU(kk,ii) = U_csf(ii,shift+kk)
|
tmpU(kk,ii) = U_csf(ii,shift+kk)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
!tmpU(1,1)=1.0d0
|
!tmpU =0.0d0
|
||||||
|
!tmpU(1,2)=1.0d0
|
||||||
double precision :: irp_rdtsc
|
double precision :: irp_rdtsc
|
||||||
double precision :: ticks_0, ticks_1
|
double precision :: ticks_0, ticks_1
|
||||||
integer*8 :: irp_imax
|
integer*8 :: irp_imax
|
||||||
@ -333,7 +334,13 @@ subroutine davidson_diag_cfg_hjj(dets_in,u_in,H_jj,energies,dim_in,sze,sze_csf,N
|
|||||||
call calculate_sigma_vector_cfg_nst_naive_store(tmpW,tmpU,N_st_diag,sze_csf,1,sze_csf,0,1)
|
call calculate_sigma_vector_cfg_nst_naive_store(tmpW,tmpU,N_st_diag,sze_csf,1,sze_csf,0,1)
|
||||||
!ticks_1 = irp_rdtsc()
|
!ticks_1 = irp_rdtsc()
|
||||||
!print *,' ----Cycles:',(ticks_1-ticks_0)/dble(irp_imax)," ----"
|
!print *,' ----Cycles:',(ticks_1-ticks_0)/dble(irp_imax)," ----"
|
||||||
!print *,' tmpW(1,1)=',tmpW(1,1)
|
!print *,' tmpW(1,2)=',tmpW(1,2)
|
||||||
|
!do ii=1,sze
|
||||||
|
! if (dabs(tmpW(1,ii)) > 1e-18) then
|
||||||
|
! print *,tmpW(1,ii)
|
||||||
|
! print *,ii,"somo=",psi_configuration(1,1,ii)," domo=",psi_configuration(1,2,ii)
|
||||||
|
! endif
|
||||||
|
!end do
|
||||||
!stop
|
!stop
|
||||||
do kk=1,N_st_diag
|
do kk=1,N_st_diag
|
||||||
do ii=1,sze_csf
|
do ii=1,sze_csf
|
||||||
|
@ -149,7 +149,7 @@ subroutine davidson_diag_hjj_sjj(dets_in,u_in,H_jj,s2_out,energies,dim_in,sze,N_
|
|||||||
character*(16384) :: write_buffer
|
character*(16384) :: write_buffer
|
||||||
double precision :: to_print(3,N_st)
|
double precision :: to_print(3,N_st)
|
||||||
double precision :: cpu, wall
|
double precision :: cpu, wall
|
||||||
integer :: shift, shift2, itermax, istate
|
integer :: shift, shift2, itermax, istate, ii
|
||||||
double precision :: r1, r2, alpha
|
double precision :: r1, r2, alpha
|
||||||
logical :: state_ok(N_st_diag_in*davidson_sze_max)
|
logical :: state_ok(N_st_diag_in*davidson_sze_max)
|
||||||
integer :: nproc_target
|
integer :: nproc_target
|
||||||
@ -362,11 +362,17 @@ subroutine davidson_diag_hjj_sjj(dets_in,u_in,H_jj,s2_out,energies,dim_in,sze,N_
|
|||||||
irp_imax = 1
|
irp_imax = 1
|
||||||
!ticks_0 = irp_rdtsc()
|
!ticks_0 = irp_rdtsc()
|
||||||
!U = 0d0
|
!U = 0d0
|
||||||
!U(1,1)=1.0d0
|
!U(4587,1)=1.0d0
|
||||||
call H_S2_u_0_nstates_openmp(W(1,shift+1),S_d,U(1,shift+1),N_st_diag,sze)
|
call H_S2_u_0_nstates_openmp(W(1,shift+1),S_d,U(1,shift+1),N_st_diag,sze)
|
||||||
!ticks_1 = irp_rdtsc()
|
!ticks_1 = irp_rdtsc()
|
||||||
!print *,' ----Cycles:',(ticks_1-ticks_0)/dble(irp_imax)," ----"
|
!print *,' ----Cycles:',(ticks_1-ticks_0)/dble(irp_imax)," ----"
|
||||||
!print *,W(1,1)
|
!print *,' tmpW(4587,1)=',W(4587,1)
|
||||||
|
!do ii=1,sze
|
||||||
|
! if (dabs(W(ii,1)) > 1e-18) then
|
||||||
|
! print *,W(ii,1)
|
||||||
|
! print *,ii,"alpha=",psi_det(1,1,ii)," beta=",psi_det(1,2,ii)
|
||||||
|
! endif
|
||||||
|
!end do
|
||||||
!stop
|
!stop
|
||||||
endif
|
endif
|
||||||
S(1:sze,shift+1:shift+N_st_diag) = real(S_d(1:sze,1:N_st_diag))
|
S(1:sze,shift+1:shift+N_st_diag) = real(S_d(1:sze,1:N_st_diag))
|
||||||
|
Loading…
Reference in New Issue
Block a user