mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-05 11:00:10 +01:00
Truncation in QMC and 4-idx
This commit is contained in:
parent
67da0834f5
commit
85862811ad
6
plugins/QMC/EZFIO.cfg
Normal file
6
plugins/QMC/EZFIO.cfg
Normal 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
|
||||||
|
|
@ -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), &
|
||||||
|
12
src/Integrals_Bielec/four_idx_transform.irp.f
Normal file
12
src/Integrals_Bielec/four_idx_transform.irp.f
Normal 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
|
Loading…
Reference in New Issue
Block a user