mirror of
https://github.com/QuantumPackage/qp2.git
synced 2025-01-08 19:32:58 +01:00
Added do_mo_cholesky
This commit is contained in:
parent
af8973770e
commit
f58df5e816
@ -6,7 +6,7 @@ default: None
|
|||||||
|
|
||||||
[io_ao_cholesky]
|
[io_ao_cholesky]
|
||||||
type: Disk_access
|
type: Disk_access
|
||||||
doc: Read/Write |AO| integrals from/to disk [ Write | Read | None ]
|
doc: Read/Write |AO| Cholesky integrals from/to disk [ Write | Read | None ]
|
||||||
interface: ezfio,provider,ocaml
|
interface: ezfio,provider,ocaml
|
||||||
default: None
|
default: None
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ END_PROVIDER
|
|||||||
deallocate(cholesky_ao)
|
deallocate(cholesky_ao)
|
||||||
|
|
||||||
if (read_ao_cholesky) then
|
if (read_ao_cholesky) then
|
||||||
print *, 'Reading Cholesky vectors from disk...'
|
print *, 'Reading Cholesky AO vectors from disk...'
|
||||||
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_ao', 'R')
|
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_ao', 'R')
|
||||||
read(iunit) rank
|
read(iunit) rank
|
||||||
allocate(cholesky_ao(ao_num,ao_num,rank), stat=ierr)
|
allocate(cholesky_ao(ao_num,ao_num,rank), stat=ierr)
|
||||||
@ -486,7 +486,7 @@ END_PROVIDER
|
|||||||
cholesky_ao_num = rank
|
cholesky_ao_num = rank
|
||||||
|
|
||||||
if (write_ao_cholesky) then
|
if (write_ao_cholesky) then
|
||||||
print *, 'Writing Cholesky vectors to disk...'
|
print *, 'Writing Cholesky AO vectors to disk...'
|
||||||
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_ao', 'W')
|
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_ao', 'W')
|
||||||
write(iunit) rank
|
write(iunit) rank
|
||||||
write(iunit) cholesky_ao
|
write(iunit) cholesky_ao
|
||||||
@ -499,7 +499,7 @@ END_PROVIDER
|
|||||||
print *, 'Rank : ', cholesky_ao_num, '(', 100.d0*dble(cholesky_ao_num)/dble(ao_num*ao_num), ' %)'
|
print *, 'Rank : ', cholesky_ao_num, '(', 100.d0*dble(cholesky_ao_num)/dble(ao_num*ao_num), ' %)'
|
||||||
print *, ''
|
print *, ''
|
||||||
call wall_time(wall1)
|
call wall_time(wall1)
|
||||||
print*,'Time to provide AO cholesky vectors = ',wall1-wall0
|
print*,'Time to provide AO cholesky vectors = ',(wall1-wall0)/60.d0, ' min'
|
||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
[io_mo_cholesky]
|
||||||
|
type: Disk_access
|
||||||
|
doc: Read/Write |MO| Cholesky integrals from/to disk [ Write | Read | None ]
|
||||||
|
interface: ezfio,provider,ocaml
|
||||||
|
default: None
|
||||||
|
|
||||||
[io_mo_two_e_integrals]
|
[io_mo_two_e_integrals]
|
||||||
type: Disk_access
|
type: Disk_access
|
||||||
doc: Read/Write |MO| integrals from/to disk [ Write | Read | None ]
|
doc: Read/Write |MO| integrals from/to disk [ Write | Read | None ]
|
||||||
|
@ -1,41 +1,73 @@
|
|||||||
|
BEGIN_PROVIDER [ logical, do_mo_cholesky ]
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! If True, use Cholesky vectors for MO integrals
|
||||||
|
END_DOC
|
||||||
|
do_mo_cholesky = do_ao_cholesky
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ integer, cholesky_mo_num ]
|
BEGIN_PROVIDER [ integer, cholesky_mo_num ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Number of Cholesky vectors in MO basis
|
! Number of Cholesky vectors in MO basis
|
||||||
END_DOC
|
END_DOC
|
||||||
|
integer, external :: getUnitAndOpen
|
||||||
|
integer :: iunit
|
||||||
|
if (read_mo_cholesky) then
|
||||||
|
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_mo_transp', 'R')
|
||||||
|
read(iunit) cholesky_mo_num
|
||||||
|
close(iunit)
|
||||||
|
else
|
||||||
cholesky_mo_num = cholesky_ao_num
|
cholesky_mo_num = cholesky_ao_num
|
||||||
|
endif
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, cholesky_mo, (mo_num, mo_num, cholesky_mo_num) ]
|
!BEGIN_PROVIDER [ double precision, cholesky_mo, (mo_num, mo_num, cholesky_mo_num) ]
|
||||||
implicit none
|
! implicit none
|
||||||
BEGIN_DOC
|
! BEGIN_DOC
|
||||||
! Cholesky vectors in MO basis
|
! ! Cholesky vectors in MO basis
|
||||||
END_DOC
|
! END_DOC
|
||||||
|
!
|
||||||
integer :: k, i, j
|
! integer :: k, i, j
|
||||||
|
!
|
||||||
call set_multiple_levels_omp(.False.)
|
! call set_multiple_levels_omp(.False.)
|
||||||
!$OMP PARALLEL DO PRIVATE(k)
|
! !$OMP PARALLEL DO PRIVATE(k)
|
||||||
do k=1,cholesky_mo_num
|
! do k=1,cholesky_mo_num
|
||||||
do j=1,mo_num
|
! do j=1,mo_num
|
||||||
do i=1,mo_num
|
! do i=1,mo_num
|
||||||
cholesky_mo(i,j,k) = cholesky_mo_transp(k,i,j)
|
! cholesky_mo(i,j,k) = cholesky_mo_transp(k,i,j)
|
||||||
enddo
|
! enddo
|
||||||
enddo
|
! enddo
|
||||||
enddo
|
! enddo
|
||||||
!$OMP END PARALLEL DO
|
! !$OMP END PARALLEL DO
|
||||||
|
!
|
||||||
END_PROVIDER
|
!END_PROVIDER
|
||||||
|
!
|
||||||
BEGIN_PROVIDER [ double precision, cholesky_mo_transp, (cholesky_mo_num, mo_num, mo_num) ]
|
BEGIN_PROVIDER [ double precision, cholesky_mo_transp, (cholesky_mo_num, mo_num, mo_num) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Cholesky vectors in MO basis
|
! Cholesky vectors in MO basis. Warning: it is transposed wrt cholesky_ao:
|
||||||
|
!
|
||||||
|
! - cholesky_ao is (ao_num^2 x cholesky_ao_num)
|
||||||
|
!
|
||||||
|
! - cholesky_mo_transp is (cholesky_mo_num x mo_num^2)
|
||||||
END_DOC
|
END_DOC
|
||||||
|
|
||||||
double precision, allocatable :: X(:,:,:)
|
double precision, allocatable :: X(:,:,:)
|
||||||
double precision :: wall0, wall1
|
double precision :: wall0, wall1
|
||||||
integer :: ierr
|
integer, external :: getUnitAndOpen
|
||||||
|
integer :: iunit, ierr, rank
|
||||||
|
|
||||||
|
if (read_mo_cholesky) then
|
||||||
|
print *, 'Reading Cholesky MO vectors from disk...'
|
||||||
|
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_mo_transp', 'R')
|
||||||
|
read(iunit) rank
|
||||||
|
if (cholesky_mo_num /= rank) then
|
||||||
|
stop 'inconsistent rank'
|
||||||
|
endif
|
||||||
|
read(iunit) cholesky_mo_transp
|
||||||
|
close(iunit)
|
||||||
|
else
|
||||||
print *, 'AO->MO Transformation of Cholesky vectors'
|
print *, 'AO->MO Transformation of Cholesky vectors'
|
||||||
call wall_time(wall0)
|
call wall_time(wall0)
|
||||||
|
|
||||||
@ -49,7 +81,18 @@ BEGIN_PROVIDER [ double precision, cholesky_mo_transp, (cholesky_mo_num, mo_num,
|
|||||||
X, ao_num, mo_coef, ao_num, 0.d0, cholesky_mo_transp, cholesky_mo_num*mo_num)
|
X, ao_num, mo_coef, ao_num, 0.d0, cholesky_mo_transp, cholesky_mo_num*mo_num)
|
||||||
deallocate(X)
|
deallocate(X)
|
||||||
call wall_time(wall1)
|
call wall_time(wall1)
|
||||||
print*,'Time for AO->MO Cholesky vectors = ',wall1-wall0
|
print*,'Time to provide MO cholesky vectors = ',(wall1-wall0)/60.d0, ' min'
|
||||||
|
|
||||||
|
|
||||||
|
if (write_mo_cholesky) then
|
||||||
|
print *, 'Writing Cholesky MO vectors to disk...'
|
||||||
|
iunit = getUnitAndOpen(trim(ezfio_work_dir)//'cholesky_mo_transp', 'W')
|
||||||
|
write(iunit) rank
|
||||||
|
write(iunit) cholesky_mo_transp
|
||||||
|
close(iunit)
|
||||||
|
call ezfio_set_mo_two_e_ints_io_mo_cholesky('Read')
|
||||||
|
endif
|
||||||
|
endif
|
||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
@ -1,12 +1,3 @@
|
|||||||
!BEGIN_PROVIDER [ logical, no_vvvv_integrals ]
|
|
||||||
! implicit none
|
|
||||||
! BEGIN_DOC
|
|
||||||
! If `True`, computes all integrals except for the integrals having 3 or 4 virtual indices
|
|
||||||
! END_DOC
|
|
||||||
!
|
|
||||||
! no_vvvv_integrals = .False.
|
|
||||||
!END_PROVIDER
|
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, mo_coef_novirt, (ao_num,n_core_inact_act_orb) ]
|
BEGIN_PROVIDER [ double precision, mo_coef_novirt, (ao_num,n_core_inact_act_orb) ]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
|
@ -10,7 +10,7 @@
|
|||||||
double precision :: get_two_e_integral
|
double precision :: get_two_e_integral
|
||||||
double precision :: integral
|
double precision :: integral
|
||||||
|
|
||||||
if (do_ao_cholesky) then
|
if (do_mo_cholesky) then
|
||||||
|
|
||||||
double precision, allocatable :: buffer_jj(:,:), buffer(:,:,:)
|
double precision, allocatable :: buffer_jj(:,:), buffer(:,:,:)
|
||||||
allocate(buffer_jj(cholesky_mo_num,mo_num), buffer(mo_num,mo_num,mo_num))
|
allocate(buffer_jj(cholesky_mo_num,mo_num), buffer(mo_num,mo_num,mo_num))
|
||||||
|
@ -1362,7 +1362,7 @@ END_PROVIDER
|
|||||||
double precision :: get_two_e_integral
|
double precision :: get_two_e_integral
|
||||||
|
|
||||||
|
|
||||||
if (do_ao_cholesky) then
|
if (do_mo_cholesky) then
|
||||||
double precision, allocatable :: buffer(:,:)
|
double precision, allocatable :: buffer(:,:)
|
||||||
allocate (buffer(cholesky_mo_num,mo_num))
|
allocate (buffer(cholesky_mo_num,mo_num))
|
||||||
do k=1,cholesky_mo_num
|
do k=1,cholesky_mo_num
|
||||||
|
@ -41,6 +41,11 @@ subroutine run(f)
|
|||||||
integer , allocatable :: Vi(:,:)
|
integer , allocatable :: Vi(:,:)
|
||||||
double precision :: s
|
double precision :: s
|
||||||
|
|
||||||
|
! TODO:
|
||||||
|
! - If Cholesky AO in trexio file, read cholesky ao vectors
|
||||||
|
! - If Cholesky MO in trexio file, read cholesky mo vectors
|
||||||
|
! - If Cholesky MO not in trexio file, force do_cholesky_mo to False
|
||||||
|
|
||||||
if (trexio_has_nucleus_repulsion(f) == TREXIO_SUCCESS) then
|
if (trexio_has_nucleus_repulsion(f) == TREXIO_SUCCESS) then
|
||||||
rc = trexio_read_nucleus_repulsion(f, s)
|
rc = trexio_read_nucleus_repulsion(f, s)
|
||||||
if (rc /= TREXIO_SUCCESS) then
|
if (rc /= TREXIO_SUCCESS) then
|
||||||
|
Loading…
Reference in New Issue
Block a user