subroutine excitation_density(nBas,nC,nO,nR,nS,ERI,XpY,rho) ! Compute excitation densities implicit none ! Input variables integer,intent(in) :: nBas,nC,nO,nR,nS double precision,intent(in) :: ERI(nBas,nBas,nBas,nBas) double precision,intent(in) :: XpY(nS,nS) ! Local variables integer :: ia,jb,x,y,j,b ! Output variables double precision,intent(out) :: rho(nBas,nBas,nS) rho(:,:,:) = 0d0 do x=nC+1,nBas-nR do y=nC+1,nBas-nR do ia=1,nS jb = 0 do j=nC+1,nO do b=nO+1,nBas-nR jb = jb + 1 rho(x,y,ia) = rho(x,y,ia) + ERI(x,j,y,b)*XpY(ia,jb) enddo enddo enddo enddo enddo end subroutine excitation_density