10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-03 10:05:57 +01:00

Truncation in QMC and 4-idx

This commit is contained in:
Anthony Scemama 2017-07-14 01:24:51 +00:00
parent 67da0834f5
commit 85862811ad
3 changed files with 26 additions and 4 deletions

6
plugins/QMC/EZFIO.cfg Normal file
View File

@ -0,0 +1,6 @@
[ci_threshold]
type: Threshold
doc: Threshold on the CI coefficients as in QMCChem
interface: ezfio,provider,ocaml
default: 1.e-8

View File

@ -15,15 +15,13 @@ program e_curve
nab = n_det_alpha_unique+n_det_beta_unique nab = n_det_alpha_unique+n_det_beta_unique
allocate ( norm_sort(0:nab), iorder(0:nab) ) allocate ( norm_sort(0:nab), iorder(0:nab) )
double precision :: thresh
integer(bit_kind), allocatable :: det_i(:,:), det_j(:,:) integer(bit_kind), allocatable :: det_i(:,:), det_j(:,:)
double precision, allocatable :: u_t(:,:), v_t(:,:), s_t(:,:) double precision, allocatable :: u_t(:,:), v_t(:,:), s_t(:,:)
double precision, allocatable :: u_0(:,:), v_0(:,:) double precision, allocatable :: u_0(:,:), v_0(:,:)
allocate(u_t(N_states,N_det),v_t(N_states,N_det),s_t(N_states,N_det)) allocate(u_t(N_states,N_det),v_t(N_states,N_det),s_t(N_states,N_det))
allocate(u_0(N_det,N_states),v_0(N_det,N_states)) allocate(u_0(N_det,N_states),v_0(N_det,N_states))
print *, 'Threshold?' read(*,*) ci_threshold
read(*,*) thresh
norm_sort(0) = 0.d0 norm_sort(0) = 0.d0
iorder(0) = 0 iorder(0) = 0
@ -45,19 +43,23 @@ program e_curve
do j=0,nab do j=0,nab
i = iorder(j) i = iorder(j)
if (i<0) then if (i<0) then
!$OMP PARALLEL DO PRIVATE(k)
do k=1,n_det do k=1,n_det
if (psi_bilinear_matrix_columns(k) == -i) then if (psi_bilinear_matrix_columns(k) == -i) then
psi_bilinear_matrix_values(k,1) = 0.d0 psi_bilinear_matrix_values(k,1) = 0.d0
endif endif
enddo enddo
!$OMP END PARALLEL DO
else else
!$OMP PARALLEL DO PRIVATE(k)
do k=1,n_det do k=1,n_det
if (psi_bilinear_matrix_rows(k) == i) then if (psi_bilinear_matrix_rows(k) == i) then
psi_bilinear_matrix_values(k,1) = 0.d0 psi_bilinear_matrix_values(k,1) = 0.d0
endif endif
enddo enddo
!$OMP END PARALLEL DO
endif endif
if (thresh > norm_sort(j)) then if (ci_threshold > norm_sort(j)) then
cycle cycle
endif endif
@ -70,7 +72,9 @@ program e_curve
u_t, & u_t, &
size(u_t, 1), & size(u_t, 1), &
N_det, N_states) N_det, N_states)
print *, 'Computing H|Psi> ...'
call H_S2_u_0_nstates_openmp_work(v_t,s_t,u_t,N_states,N_det,1,N_det,0,1) call H_S2_u_0_nstates_openmp_work(v_t,s_t,u_t,N_states,N_det,1,N_det,0,1)
print *, 'Done'
call dtranspose( & call dtranspose( &
v_t, & v_t, &
size(v_t, 1), & size(v_t, 1), &

View File

@ -0,0 +1,12 @@
program four_idx
implicit none
BEGIN_DOC
! 4-index transformation from AO to MO integrals
END_DOC
disk_access_mo_integrals = 'Write'
SOFT_TOUCH disk_access_mo_integrals
if (.true.) then
PROVIDE mo_bielec_integrals_in_map
endif
end