mirror of
https://gitlab.com/scemama/qp_plugins_scemama.git
synced 2025-01-03 01:55:52 +01:00
Compare commits
2 Commits
ad2b6b97c6
...
531cabe735
Author | SHA1 | Date | |
---|---|---|---|
531cabe735 | |||
8efcf7a649 |
@ -1,33 +1,12 @@
|
|||||||
program e_curve
|
program e_curve
|
||||||
use bitmasks
|
use bitmasks
|
||||||
implicit none
|
implicit none
|
||||||
integer :: i,j,k, kk, nab, m, l
|
integer :: i,j,k, nab, m, l
|
||||||
double precision :: norm, E, hij, num, ci, cj
|
double precision :: norm
|
||||||
integer, allocatable :: iorder(:)
|
integer, allocatable :: iorder(:)
|
||||||
double precision , allocatable :: norm_sort(:)
|
double precision , allocatable :: norm_sort(:)
|
||||||
double precision :: e_0(N_states)
|
|
||||||
PROVIDE mo_two_e_integrals_in_map mo_one_e_integrals
|
PROVIDE mo_two_e_integrals_in_map mo_one_e_integrals
|
||||||
|
|
||||||
nab = n_det_alpha_unique+n_det_beta_unique
|
|
||||||
allocate ( norm_sort(0:nab), iorder(0:nab) )
|
|
||||||
|
|
||||||
double precision, allocatable :: u_t(:,:), v_t(:,:), s_t(:,:)
|
|
||||||
double precision, allocatable :: u_0(:,:), v_0(:,:)
|
|
||||||
|
|
||||||
|
|
||||||
norm_sort(0) = 0.d0
|
|
||||||
iorder(0) = 0
|
|
||||||
do i=1,n_det_alpha_unique
|
|
||||||
norm_sort(i) = det_alpha_norm(i)
|
|
||||||
iorder(i) = i
|
|
||||||
enddo
|
|
||||||
|
|
||||||
do i=1,n_det_beta_unique
|
|
||||||
norm_sort(i+n_det_alpha_unique) = det_beta_norm(i)
|
|
||||||
iorder(i+n_det_alpha_unique) = -i
|
|
||||||
enddo
|
|
||||||
|
|
||||||
call dsort(norm_sort(1),iorder(1),nab)
|
|
||||||
|
|
||||||
if (.not.read_wf) then
|
if (.not.read_wf) then
|
||||||
stop 'Please set read_wf to true'
|
stop 'Please set read_wf to true'
|
||||||
@ -35,40 +14,67 @@ program e_curve
|
|||||||
|
|
||||||
PROVIDE psi_bilinear_matrix_values nuclear_repulsion
|
PROVIDE psi_bilinear_matrix_values nuclear_repulsion
|
||||||
|
|
||||||
|
if (.True.) then
|
||||||
|
print *, ''
|
||||||
|
print *, 'Energy: ', psi_energy(1)+nuclear_repulsion
|
||||||
|
endif
|
||||||
print *, ''
|
print *, ''
|
||||||
print *, '=============================='
|
print *, '=============================='
|
||||||
print *, 'Energies at different cut-offs'
|
print *, 'Energies at different cut-offs'
|
||||||
print *, '=============================='
|
print *, '=============================='
|
||||||
print *, ''
|
print *, ''
|
||||||
print *, '=========================================================='
|
print *, '=============================================================================='
|
||||||
print '(A8,2X,A8,2X,A12,2X,A10,2X,A12)', 'Thresh.', 'Ndet', 'Cost', 'Norm', 'E'
|
|
||||||
print *, '=========================================================='
|
print '(A8,2X,A8,A8,A8,2X,A12,2X,A10,2X,A12)', 'Thresh.', 'Ndet', 'Na', 'Nb', 'Cost', 'Norm', 'E'
|
||||||
|
print *, '=============================================================================='
|
||||||
double precision :: thresh
|
double precision :: thresh
|
||||||
integer(bit_kind), allocatable :: det_i(:,:), det_j(:,:)
|
integer(bit_kind), allocatable :: det_i(:,:), det_j(:,:)
|
||||||
integer :: na, nb
|
integer :: na, nb
|
||||||
thresh = 1.d-10
|
|
||||||
na = n_det_alpha_unique
|
nab = n_det_alpha_unique+n_det_beta_unique
|
||||||
nb = n_det_beta_unique
|
allocate ( norm_sort(0:nab), iorder(0:nab) )
|
||||||
do j=0,nab
|
thresh = 1.d-8
|
||||||
i = iorder(j)
|
|
||||||
if (i<0) then
|
do while (N_det > 1)
|
||||||
nb -= 1
|
nab = n_det_alpha_unique+n_det_beta_unique
|
||||||
do k=1,n_det
|
|
||||||
if (psi_bilinear_matrix_columns(k) == -i) then
|
norm_sort(0) = 0.d0
|
||||||
psi_bilinear_matrix_values(k,1) = 0.d0
|
iorder(0) = 0
|
||||||
endif
|
do i=1,n_det_alpha_unique
|
||||||
enddo
|
norm_sort(i) = det_alpha_norm(i)
|
||||||
else
|
iorder(i) = i
|
||||||
na -= 1
|
enddo
|
||||||
do k=1,n_det
|
|
||||||
if (psi_bilinear_matrix_rows(k) == i) then
|
do i=1,n_det_beta_unique
|
||||||
psi_bilinear_matrix_values(k,1) = 0.d0
|
norm_sort(i+n_det_alpha_unique) = det_beta_norm(i)
|
||||||
endif
|
iorder(i+n_det_alpha_unique) = -i
|
||||||
enddo
|
enddo
|
||||||
endif
|
|
||||||
if (thresh > norm_sort(j)) then
|
call dsort(norm_sort(1),iorder(1),nab)
|
||||||
cycle
|
|
||||||
endif
|
na = n_det_alpha_unique
|
||||||
|
nb = n_det_beta_unique
|
||||||
|
do j=1,nab
|
||||||
|
i = iorder(j)
|
||||||
|
if ((i<0).and.(nb>1)) then
|
||||||
|
nb -= 1
|
||||||
|
do k=1,n_det
|
||||||
|
if (psi_bilinear_matrix_columns(k) == -i) then
|
||||||
|
psi_bilinear_matrix_values(k,1) = 0.d0
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
else if ((i>0).and.(na>1)) then
|
||||||
|
na -= 1
|
||||||
|
do k=1,n_det
|
||||||
|
if (psi_bilinear_matrix_rows(k) == i) then
|
||||||
|
psi_bilinear_matrix_values(k,1) = 0.d0
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
|
if (thresh < norm_sort(j)) then
|
||||||
|
exit
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
|
||||||
do k=1,N_states
|
do k=1,N_states
|
||||||
psi_coef(1:N_det,k) = psi_bilinear_matrix_values(1:N_det,k)
|
psi_coef(1:N_det,k) = psi_bilinear_matrix_values(1:N_det,k)
|
||||||
@ -76,30 +82,31 @@ program e_curve
|
|||||||
enddo
|
enddo
|
||||||
TOUCH psi_det psi_coef
|
TOUCH psi_det psi_coef
|
||||||
|
|
||||||
m = 0
|
psi_det = psi_det_sorted
|
||||||
do k=1,n_det
|
psi_coef = psi_coef_sorted
|
||||||
if (psi_bilinear_matrix_values(k,1) /= 0.d0) then
|
|
||||||
m = m+1
|
do m=1,n_det
|
||||||
endif
|
if (psi_coef_sorted(m,1) == 0.d0) exit
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
if (m == 0) then
|
N_det = m-1
|
||||||
exit
|
TOUCH psi_det psi_coef N_det
|
||||||
|
|
||||||
|
! Avoid providing psi_energy
|
||||||
|
if (.True.) then
|
||||||
|
double precision :: cost0, cost
|
||||||
|
cost0 = elec_alpha_num**3 + elec_beta_num**3
|
||||||
|
cost = (na-1) * elec_alpha_num**2 + &
|
||||||
|
(nb-1) * elec_beta_num**2 + &
|
||||||
|
elec_alpha_num**3 + elec_beta_num**3
|
||||||
|
cost = cost/cost0
|
||||||
|
|
||||||
|
double precision :: u_dot_u
|
||||||
|
norm = dsqrt(u_dot_u(psi_coef(1,1),N_det))
|
||||||
|
print '(E9.1,2X,I8,I8,I8,2X,F10.2,2X,F10.8,2X,F15.10)', thresh, N_det, &
|
||||||
|
na, nb, cost, norm, psi_energy(1) + nuclear_repulsion
|
||||||
|
thresh = thresh * dsqrt(10.d0)
|
||||||
endif
|
endif
|
||||||
E = E_0(1) + nuclear_repulsion
|
|
||||||
|
|
||||||
double precision :: cost0, cost
|
|
||||||
cost0 = elec_alpha_num**3 + elec_beta_num**3
|
|
||||||
cost = (na-1) * elec_alpha_num**2 + &
|
|
||||||
(nb-1) * elec_beta_num**2 + &
|
|
||||||
elec_alpha_num**3 + elec_beta_num**3
|
|
||||||
cost = cost/cost0
|
|
||||||
|
|
||||||
double precision :: u_dot_u
|
|
||||||
norm = dsqrt(u_dot_u(psi_coef(1,1),N_det))
|
|
||||||
print '(E9.1,2X,I8,2X,F10.2,2X,F10.8,2X,F15.10)', thresh, m, &
|
|
||||||
cost, norm, psi_energy(1)
|
|
||||||
thresh = thresh * dsqrt(10.d0)
|
|
||||||
enddo
|
enddo
|
||||||
print *, '=========================================================='
|
print *, '=========================================================='
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user