10
0
mirror of https://github.com/QuantumPackage/qp2.git synced 2025-01-05 02:48:49 +01:00

Introducing dgemm and dgemv to get integrals

This commit is contained in:
Anthony Scemama 2024-06-10 18:23:45 +02:00
parent bd534589e1
commit 10fb3a0636
2 changed files with 33 additions and 8 deletions

View File

@ -262,9 +262,25 @@ subroutine get_mo_two_e_integrals_ij(k,l,sze,out_array,map)
integer :: j integer :: j
real(integral_kind), allocatable :: tmp_val(:) real(integral_kind), allocatable :: tmp_val(:)
if (do_mo_cholesky) then
call dgemm('T', 'N', mo_num, mo_num, cholesky_mo_num, 1.d0, &
cholesky_mo_transp(1,1,k), cholesky_mo_num, &
cholesky_mo_transp(1,1,l), cholesky_mo_num, 0.d0, &
out_array, sze)
! integer :: i
! do j=1,mo_num
! do i=1,mo_num
! double precision, external :: get_two_e_integral
! print *, i, j, real(out_array(i,j)), real(get_two_e_integral(i,j,k,l,map))
! enddo
! enddo
! print *, irp_here
! pause
else
do j=1,sze do j=1,sze
call get_mo_two_e_integrals(j,k,l,sze,out_array(1,j),map) call get_mo_two_e_integrals(j,k,l,sze,out_array(1,j),map)
enddo enddo
endif
end end
subroutine get_mo_two_e_integrals_i1j1(k,l,sze,out_array,map) subroutine get_mo_two_e_integrals_i1j1(k,l,sze,out_array,map)
@ -303,9 +319,16 @@ subroutine get_mo_two_e_integrals_coulomb_ii(k,l,sze,out_val,map)
double precision, external :: get_two_e_integral double precision, external :: get_two_e_integral
PROVIDE mo_two_e_integrals_in_map PROVIDE mo_two_e_integrals_in_map
if (do_mo_cholesky) then
call dgemv('T', cholesky_mo_num, mo_num, 1.d0, &
cholesky_mo_transp(1,1,1), cholesky_mo_num*(mo_num+1), &
cholesky_mo_transp(1,k,l), 1, 0.d0, &
out_val, 1)
else
do i=1,sze do i=1,sze
out_val(i) = get_two_e_integral(k,i,l,i,map) out_val(i) = get_two_e_integral(k,i,l,i,map)
enddo enddo
endif
end end

View File

@ -65,9 +65,11 @@ BEGIN_PROVIDER [ logical, mo_two_e_integrals_in_map ]
call cpu_time(cpu_1) call cpu_time(cpu_1)
if (do_mo_cholesky) then if (do_mo_cholesky) then
call add_integrals_to_map_cholesky PROVIDE cholesky_mo_transp
else else
if (dble(ao_num)**4 * 32.d-9 < dble(qp_max_mem)) then if (do_ao_cholesky) then
call add_integrals_to_map_cholesky
else if (dble(ao_num)**4 * 32.d-9 < dble(qp_max_mem)) then
call four_idx_dgemm call four_idx_dgemm
else else
call add_integrals_to_map(full_ijkl_bitmask_4) call add_integrals_to_map(full_ijkl_bitmask_4)