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

NEEDS IRPF90 1.4.1 -- Cleaned all PROVIDEs

This commit is contained in:
Anthony Scemama 2014-10-08 23:24:55 +02:00
parent 0ee2a47d2e
commit 1f17af5306
16 changed files with 12 additions and 77 deletions

View File

@ -1,19 +0,0 @@
BEGIN_PROVIDER [ logical, all_ao_integrals ]
implicit none
BEGIN_DOC
! Forces all provieders of AO integrals to be provided
END_DOC
PROVIDE all_utils nucl_coord ao_overlap_abs ao_overlap
END_PROVIDER
BEGIN_PROVIDER [ logical, all_mo_integrals ]
implicit none
BEGIN_DOC
! Forces all provieders of MO integrals to be provided
END_DOC
PROVIDE all_utils nucl_coord mo_bielec_integral_jj
PROVIDE mo_bielec_integral_jj_exchange mo_bielec_integral_jj_anti
END_PROVIDER

View File

@ -20,8 +20,6 @@ double precision function ao_bielec_integral(i,j,k,l)
return return
endif endif
PROVIDE all_utils
dim1 = n_pt_max_integrals dim1 = n_pt_max_integrals
num_i = ao_nucl(i) num_i = ao_nucl(i)
@ -124,8 +122,6 @@ double precision function ao_bielec_integral_schwartz_accel(i,j,k,l)
double precision, allocatable :: schwartz_kl(:,:) double precision, allocatable :: schwartz_kl(:,:)
double precision :: schwartz_ij double precision :: schwartz_ij
PROVIDE all_utils
dim1 = n_pt_max_integrals dim1 = n_pt_max_integrals
num_i = ao_nucl(i) num_i = ao_nucl(i)
@ -307,8 +303,6 @@ subroutine compute_ao_bielec_integrals(j,k,l,sze,buffer_value)
integer :: n_centers, i integer :: n_centers, i
PROVIDE gauleg_t2 ao_nucl all_utils
if (ao_overlap_abs(j,l) < thresh) then if (ao_overlap_abs(j,l) < thresh) then
buffer_value = 0._integral_kind buffer_value = 0._integral_kind
return return
@ -355,8 +349,6 @@ BEGIN_PROVIDER [ logical, ao_bielec_integrals_in_map ]
integer :: n_integrals, n_centers, thread_num integer :: n_integrals, n_centers, thread_num
integer :: jl_pairs(2,ao_num*(ao_num+1)/2), kk, m, j1, i1, lmax integer :: jl_pairs(2,ao_num*(ao_num+1)/2), kk, m, j1, i1, lmax
PROVIDE gauleg_t2 ao_integrals_map all_utils
PROVIDE ao_bielec_integral_schwartz
integral = ao_bielec_integral(1,1,1,1) integral = ao_bielec_integral(1,1,1,1)
real :: map_mb real :: map_mb
@ -378,7 +370,6 @@ BEGIN_PROVIDER [ logical, ao_bielec_integrals_in_map ]
enddo enddo
enddo enddo
PROVIDE ao_nucl
PROVIDE progress_bar PROVIDE progress_bar
call omp_init_lock(lock) call omp_init_lock(lock)
lmax = ao_num*(ao_num+1)/2 lmax = ao_num*(ao_num+1)/2
@ -511,7 +502,6 @@ BEGIN_PROVIDER [ double precision, ao_bielec_integral_schwartz,(ao_num,ao_num)
integer :: i,k integer :: i,k
double precision :: ao_bielec_integral,cpu_1,cpu_2, wall_1, wall_2 double precision :: ao_bielec_integral,cpu_1,cpu_2, wall_1, wall_2
PROVIDE gauleg_t2 ao_integrals_map
ao_bielec_integral_schwartz(1,1) = ao_bielec_integral(1,1,1,1) ao_bielec_integral_schwartz(1,1) = ao_bielec_integral(1,1,1,1)
!$OMP PARALLEL DO PRIVATE(i,k) & !$OMP PARALLEL DO PRIVATE(i,k) &
!$OMP DEFAULT(NONE) & !$OMP DEFAULT(NONE) &

View File

@ -9,7 +9,6 @@ BEGIN_PROVIDER [ type(map_type), ao_integrals_map ]
! AO integrals ! AO integrals
END_DOC END_DOC
integer*8 :: sze integer*8 :: sze
PROVIDE gauleg_t2
call bielec_integrals_index(ao_num,ao_num,ao_num,ao_num,sze) call bielec_integrals_index(ao_num,ao_num,ao_num,ao_num,sze)
call map_init(ao_integrals_map,sze) call map_init(ao_integrals_map,sze)
write(output_BiInts,*) 'AO map initialized' write(output_BiInts,*) 'AO map initialized'

View File

@ -25,8 +25,6 @@ BEGIN_PROVIDER [ logical, mo_bielec_integrals_in_map ]
! If True, the map of MO bielectronic integrals is provided ! If True, the map of MO bielectronic integrals is provided
END_DOC END_DOC
PROVIDE all_mo_integrals
mo_bielec_integrals_in_map = .True. mo_bielec_integrals_in_map = .True.
if (read_mo_integrals) then if (read_mo_integrals) then
integer :: load_mo_integrals integer :: load_mo_integrals
@ -72,7 +70,7 @@ subroutine add_integrals_to_map(mask_ijkl)
integer :: i2,i3,i4 integer :: i2,i3,i4
double precision,parameter :: thr_coef = 0.d0 double precision,parameter :: thr_coef = 0.d0
PROVIDE N_int ao_bielec_integrals_in_map ao_integrals_map mo_coef mo_coef_transp PROVIDE ao_bielec_integrals_in_map
!Get list of MOs for i,j,k and l !Get list of MOs for i,j,k and l
!------------------------------- !-------------------------------
@ -340,11 +338,8 @@ end
double precision, allocatable :: iqrs(:,:), iqsr(:,:), iqis(:), iqri(:) double precision, allocatable :: iqrs(:,:), iqsr(:,:), iqis(:), iqri(:)
PROVIDE ao_integrals_threshold
if (.not.do_direct_integrals) then if (.not.do_direct_integrals) then
PROVIDE ao_bielec_integrals_in_map PROVIDE ao_bielec_integrals_in_map
else
PROVIDE ao_overlap_abs
endif endif
mo_bielec_integral_jj = 0.d0 mo_bielec_integral_jj = 0.d0

View File

@ -378,14 +378,10 @@ subroutine $subroutine($params_main)
integer :: iproc integer :: iproc
PROVIDE H_apply_buffer_allocated mo_bielec_integrals_in_map PROVIDE H_apply_buffer_allocated mo_bielec_integrals_in_map
PROVIDE N_det_selectors psi_generators HF_energy
PROVIDE psi_det_sorted_bit coef_hf_selector psi_det psi_coef
PROVIDE mo_mono_elec_integral ref_bitmask_energy
nmax = ( N_det_generators/nproc ) *nproc nmax = ( N_det_generators/nproc ) *nproc
PROVIDE progress_bar
call start_progress(N_det_generators,'Selection (norm)',0.d0) call start_progress(N_det_generators,'Selection (norm)',0.d0)
!$ call omp_init_lock(lck) !$ call omp_init_lock(lck)

View File

@ -22,7 +22,6 @@ subroutine CISD_SC2(dets_in,u_in,energies,dim_in,sze,N_st,Nint,convergence)
double precision, intent(inout) :: u_in(dim_in,N_st) double precision, intent(inout) :: u_in(dim_in,N_st)
double precision, intent(out) :: energies(N_st) double precision, intent(out) :: energies(N_st)
double precision, intent(in) :: convergence double precision, intent(in) :: convergence
PROVIDE ref_bitmask_energy
ASSERT (N_st > 0) ASSERT (N_st > 0)
ASSERT (sze > 0) ASSERT (sze > 0)
ASSERT (Nint > 0) ASSERT (Nint > 0)

View File

@ -48,7 +48,7 @@ subroutine davidson_diag(dets_in,u_in,energies,dim_in,sze,N_st,Nint,iunit)
ASSERT (sze > 0) ASSERT (sze > 0)
ASSERT (Nint > 0) ASSERT (Nint > 0)
ASSERT (Nint == N_int) ASSERT (Nint == N_int)
PROVIDE ref_bitmask_energy mo_bielec_integrals_in_map PROVIDE mo_bielec_integrals_in_map
allocate(H_jj(sze)) allocate(H_jj(sze))
!$OMP PARALLEL DEFAULT(NONE) & !$OMP PARALLEL DEFAULT(NONE) &
@ -114,7 +114,7 @@ subroutine davidson_diag_hjj(dets_in,u_in,H_jj,energies,dim_in,sze,N_st,Nint,iun
double precision :: to_print(2,N_st) double precision :: to_print(2,N_st)
double precision :: cpu, wall double precision :: cpu, wall
PROVIDE N_con_int det_connections PROVIDE det_connections
call write_time(iunit) call write_time(iunit)
call wall_time(wall) call wall_time(wall)
@ -141,7 +141,6 @@ subroutine davidson_diag_hjj(dets_in,u_in,H_jj,energies,dim_in,sze,N_st,Nint,iun
write_buffer = trim(write_buffer)//' ================ ================' write_buffer = trim(write_buffer)//' ================ ================'
enddo enddo
write(iunit,'(A)') trim(write_buffer) write(iunit,'(A)') trim(write_buffer)
PROVIDE ref_bitmask_energy davidson_criterion
allocate( & allocate( &
kl_pairs(2,N_st*(N_st+1)/2), & kl_pairs(2,N_st*(N_st+1)/2), &

View File

@ -112,9 +112,6 @@ END_PROVIDER
double precision :: integral double precision :: integral
double precision :: ao_bielec_integral double precision :: ao_bielec_integral
if (do_direct_integrals) then if (do_direct_integrals) then
PROVIDE all_utils ao_overlap_abs ao_integrals_threshold gauleg_t2
PROVIDE HF_density_matrix_ao_alpha HF_density_matrix_ao_beta
PROVIDE ao_bi_elec_integral_alpha
ao_bi_elec_integral_alpha = 0.d0 ao_bi_elec_integral_alpha = 0.d0
ao_bi_elec_integral_beta = 0.d0 ao_bi_elec_integral_beta = 0.d0

View File

@ -11,8 +11,6 @@
integer :: occ(N_int*bit_kind_size,2) integer :: occ(N_int*bit_kind_size,2)
integer :: i,j integer :: i,j
PROVIDE mo_mono_elec_integral
call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int) call bitstring_to_list(ref_bitmask(1,1), occ(1,1), i, N_int)
call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int) call bitstring_to_list(ref_bitmask(1,2), occ(1,2), i, N_int)

View File

@ -1,4 +1,4 @@
program cisd program mp2
implicit none implicit none
double precision, allocatable :: pt2(:), norm_pert(:) double precision, allocatable :: pt2(:), norm_pert(:)
double precision :: H_pert_diag, E_old double precision :: H_pert_diag, E_old

View File

@ -20,6 +20,7 @@ endif
ifeq ($(OPENMP),1) ifeq ($(OPENMP),1)
FC += -openmp FC += -openmp
IRPF90_FLAGS += --openmp
CXX += -fopenmp CXX += -fopenmp
endif endif

View File

@ -15,6 +15,7 @@ endif
ifeq ($(OPENMP),1) ifeq ($(OPENMP),1)
FC += -fopenmp FC += -fopenmp
IRPF90_FLAGS += --openmp
endif endif
ifeq ($(DEBUG),1) ifeq ($(DEBUG),1)

View File

@ -19,6 +19,7 @@ endif
ifeq ($(OPENMP),1) ifeq ($(OPENMP),1)
FC += -openmp FC += -openmp
IRPF90_FLAGS += --openmp
CXX += -fopenmp CXX += -fopenmp
endif endif

View File

@ -11,7 +11,6 @@
double precision :: A_center(3), B_center(3) double precision :: A_center(3), B_center(3)
integer :: power_A(3), power_B(3) integer :: power_A(3), power_B(3)
double precision :: d_a_2,d_2 double precision :: d_a_2,d_2
PROVIDE all_utils
dim1=100 dim1=100
BEGIN_DOC BEGIN_DOC
! second derivatives matrix elements in the ao basis ! second derivatives matrix elements in the ao basis

View File

@ -11,7 +11,6 @@
double precision ::overlap_x,overlap_y,overlap_z,overlap,dx,NAI_pol_mult double precision ::overlap_x,overlap_y,overlap_z,overlap,dx,NAI_pol_mult
integer :: nucl_numC integer :: nucl_numC
! Important for OpenMP ! Important for OpenMP
PROVIDE all_utils
ao_nucl_elec_integral = 0.d0 ao_nucl_elec_integral = 0.d0

View File

@ -1,23 +1,3 @@
BEGIN_PROVIDER [ logical, all_utils ]
implicit none
BEGIN_DOC
! Dummy provider to provide all utils
END_DOC
! Do not move this : it greps itself
BEGIN_SHELL [ /bin/bash ]
for i in $(grep "BEGIN_PROVIDER" $QPACKAGE_ROOT/src/Utils/*.irp.f \
| grep ',' | cut -d ',' -f 2 | cut -d ']' -f 1 | tail --lines=+3 )
do
if [[ ! -z $i ]]
then
echo PROVIDE $i
fi
done
END_SHELL
call trap_signals
END_PROVIDER
double precision function binom_func(i,j) double precision function binom_func(i,j)
implicit none implicit none
BEGIN_DOC BEGIN_DOC