2019-01-25 11:39:31 +01:00
|
|
|
BEGIN_PROVIDER [ double precision, ao_one_e_integrals,(ao_num,ao_num)]
|
|
|
|
&BEGIN_PROVIDER [ double precision, ao_one_e_integrals_diag,(ao_num)]
|
|
|
|
implicit none
|
|
|
|
integer :: i,j,n,l
|
|
|
|
BEGIN_DOC
|
|
|
|
! One-electron Hamiltonian in the |AO| basis.
|
|
|
|
END_DOC
|
|
|
|
|
|
|
|
IF (read_ao_one_e_integrals) THEN
|
|
|
|
call ezfio_get_ao_one_e_ints_ao_one_e_integrals(ao_one_e_integrals)
|
|
|
|
ELSE
|
2024-10-31 15:13:02 +01:00
|
|
|
ao_one_e_integrals = ao_integrals_n_e + ao_kinetic_integrals
|
2019-01-25 11:39:31 +01:00
|
|
|
|
|
|
|
ENDIF
|
|
|
|
|
|
|
|
DO j = 1, ao_num
|
|
|
|
ao_one_e_integrals_diag(j) = ao_one_e_integrals(j,j)
|
|
|
|
ENDDO
|
|
|
|
|
|
|
|
IF (write_ao_one_e_integrals) THEN
|
|
|
|
call ezfio_set_ao_one_e_ints_ao_one_e_integrals(ao_one_e_integrals)
|
|
|
|
print *, 'AO one-e integrals written to disk'
|
|
|
|
ENDIF
|
|
|
|
|
|
|
|
END_PROVIDER
|
|
|
|
|
2019-12-02 18:18:30 +01:00
|
|
|
BEGIN_PROVIDER [ double precision, ao_one_e_integrals_imag,(ao_num,ao_num)]
|
|
|
|
implicit none
|
|
|
|
integer :: i,j,n,l
|
|
|
|
BEGIN_DOC
|
|
|
|
! One-electron Hamiltonian in the |AO| basis.
|
|
|
|
END_DOC
|
|
|
|
|
|
|
|
IF (read_ao_one_e_integrals) THEN
|
|
|
|
call ezfio_get_ao_one_e_ints_ao_one_e_integrals(ao_one_e_integrals_imag)
|
|
|
|
ELSE
|
|
|
|
print *, irp_here, ': Not yet implemented'
|
|
|
|
stop -1
|
|
|
|
ENDIF
|
|
|
|
|
|
|
|
IF (write_ao_one_e_integrals) THEN
|
|
|
|
call ezfio_set_ao_one_e_ints_ao_one_e_integrals(ao_one_e_integrals_imag)
|
|
|
|
print *, 'AO one-e integrals written to disk'
|
|
|
|
ENDIF
|
|
|
|
|
|
|
|
END_PROVIDER
|
|
|
|
|
2024-03-22 14:56:39 +01:00
|
|
|
|
|
|
|
BEGIN_PROVIDER [ double precision, ao_one_e_integrals_from_mo, (ao_num, ao_num)]
|
|
|
|
implicit none
|
|
|
|
BEGIN_DOC
|
|
|
|
! Integrals of the one e hamiltonian obtained from the integrals on the MO basis
|
|
|
|
!
|
|
|
|
! WARNING : this is equal to ao_one_e_integrals only if the AO and MO basis have the same number of functions
|
|
|
|
END_DOC
|
|
|
|
call mo_to_ao(mo_one_e_integrals,mo_num,ao_one_e_integrals_from_mo,ao_num)
|
|
|
|
END_PROVIDER
|