mirror of
https://github.com/pfloos/quack
synced 2025-01-03 18:16:03 +01:00
workin on numgrid
This commit is contained in:
parent
08a4d4e4e9
commit
23e752f5d1
@ -3,6 +3,7 @@
|
|||||||
integer,parameter :: nsp = 3
|
integer,parameter :: nsp = 3
|
||||||
integer,parameter :: maxEns = 10
|
integer,parameter :: maxEns = 10
|
||||||
integer,parameter :: maxShell = 512
|
integer,parameter :: maxShell = 512
|
||||||
|
integer,parameter :: maxL = 7
|
||||||
integer,parameter :: n1eInt = 3
|
integer,parameter :: n1eInt = 3
|
||||||
integer,parameter :: n2eInt = 4
|
integer,parameter :: n2eInt = 4
|
||||||
integer,parameter :: n3eInt = 3
|
integer,parameter :: n3eInt = 3
|
||||||
|
49
input/basis
49
input/basis
@ -1,49 +1,18 @@
|
|||||||
1 9
|
1 3
|
||||||
S 8
|
|
||||||
1 1469.0000000 0.0007660
|
|
||||||
2 220.5000000 0.0058920
|
|
||||||
3 50.2600000 0.0296710
|
|
||||||
4 14.2400000 0.1091800
|
|
||||||
5 4.5810000 0.2827890
|
|
||||||
6 1.5800000 0.4531230
|
|
||||||
7 0.5640000 0.2747740
|
|
||||||
8 0.0734500 0.0097510
|
|
||||||
S 8
|
|
||||||
1 1469.0000000 -0.0001200
|
|
||||||
2 220.5000000 -0.0009230
|
|
||||||
3 50.2600000 -0.0046890
|
|
||||||
4 14.2400000 -0.0176820
|
|
||||||
5 4.5810000 -0.0489020
|
|
||||||
6 1.5800000 -0.0960090
|
|
||||||
7 0.5640000 -0.1363800
|
|
||||||
8 0.0734500 0.5751020
|
|
||||||
S 1
|
|
||||||
1 0.0280500 1.0000000
|
|
||||||
S 1
|
|
||||||
1 0.0086400 1.0000000
|
|
||||||
P 3
|
|
||||||
1 1.5340000 0.0227840
|
|
||||||
2 0.2749000 0.1391070
|
|
||||||
3 0.0736200 0.5003750
|
|
||||||
P 1
|
|
||||||
1 0.0240300 1.0000000
|
|
||||||
P 1
|
|
||||||
1 0.0057900 1.0000000
|
|
||||||
D 1
|
|
||||||
1 0.1239000 1.0000000
|
|
||||||
D 1
|
|
||||||
1 0.0725000 1.0000000
|
|
||||||
2 5
|
|
||||||
S 3
|
S 3
|
||||||
1 13.0100000 0.0196850
|
1 13.0100000 0.0196850
|
||||||
2 1.9620000 0.1379770
|
2 1.9620000 0.1379770
|
||||||
3 0.4446000 0.4781480
|
3 0.4446000 0.4781480
|
||||||
S 1
|
S 1
|
||||||
1 0.1220000 1.0000000
|
1 0.1220000 1.0000000
|
||||||
S 1
|
|
||||||
1 0.0297400 1.0000000
|
|
||||||
P 1
|
P 1
|
||||||
1 0.7270000 1.0000000
|
1 0.7270000 1.0000000
|
||||||
|
2 3
|
||||||
|
S 3
|
||||||
|
1 13.0100000 0.0196850
|
||||||
|
2 1.9620000 0.1379770
|
||||||
|
3 0.4446000 0.4781480
|
||||||
|
S 1
|
||||||
|
1 0.1220000 1.0000000
|
||||||
P 1
|
P 1
|
||||||
1 0.1410000 1.0000000
|
1 0.7270000 1.0000000
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# Restricted or unrestricted KS calculation
|
# Restricted or unrestricted KS calculation
|
||||||
LIM-RKS
|
GOK-RKS
|
||||||
# exchange rung:
|
# exchange rung:
|
||||||
# Hartree = 0
|
# Hartree = 0
|
||||||
# LDA = 1: RS51,RMFL20
|
# LDA = 1: RS51,RMFL20
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
# RHF UHF MOM
|
# RHF UHF MOM
|
||||||
T F F
|
T F F
|
||||||
# MP2 MP3 MP2-F12
|
# MP2 MP3 MP2-F12
|
||||||
T F F
|
F F F
|
||||||
# CCD CCSD CCSD(T)
|
# CCD CCSD CCSD(T)
|
||||||
F F F
|
F F F
|
||||||
# drCCD rCCD lCCD pCCD
|
# drCCD rCCD lCCD pCCD
|
||||||
@ -9,7 +9,7 @@
|
|||||||
# CIS RPA RPAx ppRPA ADC
|
# CIS RPA RPAx ppRPA ADC
|
||||||
F F F F F
|
F F F F F
|
||||||
# G0F2 evGF2 G0F3 evGF3
|
# G0F2 evGF2 G0F3 evGF3
|
||||||
T F F F
|
F F F F
|
||||||
# G0W0 evGW qsGW
|
# G0W0 evGW qsGW
|
||||||
F F F
|
F F F
|
||||||
# G0T0 evGT qsGT
|
# G0T0 evGT qsGT
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
# nAt nEla nElb nCore nRyd
|
# nAt nEla nElb nCore nRyd
|
||||||
2 2 2 0 0
|
2 1 1 0 0
|
||||||
# Znuc x y z
|
# Znuc x y z
|
||||||
Li 0. 0. 0.
|
H 0. 0. 0.
|
||||||
H 0. 0. 3.099
|
H 0. 0. 1.4
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
2
|
2
|
||||||
|
|
||||||
Li 0.0000000000 0.0000000000 0.0000000000
|
H 0.0000000000 0.0000000000 0.0000000000
|
||||||
H 0.0000000000 0.0000000000 1.6399202947
|
H 0.0000000000 0.0000000000 0.7408481486
|
||||||
|
49
input/weight
49
input/weight
@ -1,49 +1,18 @@
|
|||||||
1 9
|
1 3
|
||||||
S 8
|
|
||||||
1 1469.0000000 0.0007660
|
|
||||||
2 220.5000000 0.0058920
|
|
||||||
3 50.2600000 0.0296710
|
|
||||||
4 14.2400000 0.1091800
|
|
||||||
5 4.5810000 0.2827890
|
|
||||||
6 1.5800000 0.4531230
|
|
||||||
7 0.5640000 0.2747740
|
|
||||||
8 0.0734500 0.0097510
|
|
||||||
S 8
|
|
||||||
1 1469.0000000 -0.0001200
|
|
||||||
2 220.5000000 -0.0009230
|
|
||||||
3 50.2600000 -0.0046890
|
|
||||||
4 14.2400000 -0.0176820
|
|
||||||
5 4.5810000 -0.0489020
|
|
||||||
6 1.5800000 -0.0960090
|
|
||||||
7 0.5640000 -0.1363800
|
|
||||||
8 0.0734500 0.5751020
|
|
||||||
S 1
|
|
||||||
1 0.0280500 1.0000000
|
|
||||||
S 1
|
|
||||||
1 0.0086400 1.0000000
|
|
||||||
P 3
|
|
||||||
1 1.5340000 0.0227840
|
|
||||||
2 0.2749000 0.1391070
|
|
||||||
3 0.0736200 0.5003750
|
|
||||||
P 1
|
|
||||||
1 0.0240300 1.0000000
|
|
||||||
P 1
|
|
||||||
1 0.0057900 1.0000000
|
|
||||||
D 1
|
|
||||||
1 0.1239000 1.0000000
|
|
||||||
D 1
|
|
||||||
1 0.0725000 1.0000000
|
|
||||||
2 5
|
|
||||||
S 3
|
S 3
|
||||||
1 13.0100000 0.0196850
|
1 13.0100000 0.0196850
|
||||||
2 1.9620000 0.1379770
|
2 1.9620000 0.1379770
|
||||||
3 0.4446000 0.4781480
|
3 0.4446000 0.4781480
|
||||||
S 1
|
S 1
|
||||||
1 0.1220000 1.0000000
|
1 0.1220000 1.0000000
|
||||||
S 1
|
|
||||||
1 0.0297400 1.0000000
|
|
||||||
P 1
|
P 1
|
||||||
1 0.7270000 1.0000000
|
1 0.7270000 1.0000000
|
||||||
|
2 3
|
||||||
|
S 3
|
||||||
|
1 13.0100000 0.0196850
|
||||||
|
2 1.9620000 0.1379770
|
||||||
|
3 0.4446000 0.4781480
|
||||||
|
S 1
|
||||||
|
1 0.1220000 1.0000000
|
||||||
P 1
|
P 1
|
||||||
1 0.1410000 1.0000000
|
1 0.7270000 1.0000000
|
||||||
|
|
||||||
|
@ -91,10 +91,8 @@ subroutine G0T0(doACFDT,exchange_kernel,doXBS,BSE,TDA,singlet_manifold,triplet_m
|
|||||||
|
|
||||||
! Compute linear response
|
! Compute linear response
|
||||||
|
|
||||||
call linear_response_pp(ispin,.true.,.false.,nBas,nC,nO,nV,nR, &
|
call linear_response_pp(ispin,.true.,.false.,nBas,nC,nO,nV,nR,nOOs,nVVs,eHF(:),ERI(:,:,:,:), &
|
||||||
nOOs,nVVs,eHF(:),ERI(:,:,:,:), &
|
Omega1s(:),X1s(:,:),Y1s(:,:),Omega2s(:),X2s(:,:),Y2s(:,:), &
|
||||||
Omega1s(:),X1s(:,:),Y1s(:,:), &
|
|
||||||
Omega2s(:),X2s(:,:),Y2s(:,:), &
|
|
||||||
EcRPA(ispin))
|
EcRPA(ispin))
|
||||||
|
|
||||||
EcRPA(ispin) = 1d0*EcRPA(ispin)
|
EcRPA(ispin) = 1d0*EcRPA(ispin)
|
||||||
@ -105,8 +103,7 @@ subroutine G0T0(doACFDT,exchange_kernel,doXBS,BSE,TDA,singlet_manifold,triplet_m
|
|||||||
! Compute excitation densities for the T-matrix
|
! Compute excitation densities for the T-matrix
|
||||||
|
|
||||||
call excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOOs,nVVs,ERI(:,:,:,:), &
|
call excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOOs,nVVs,ERI(:,:,:,:), &
|
||||||
X1s(:,:),Y1s(:,:),rho1s(:,:,:), &
|
X1s(:,:),Y1s(:,:),rho1s(:,:,:),X2s(:,:),Y2s(:,:),rho2s(:,:,:))
|
||||||
X2s(:,:),Y2s(:,:),rho2s(:,:,:))
|
|
||||||
|
|
||||||
!----------------------------------------------
|
!----------------------------------------------
|
||||||
! Triplet manifold
|
! Triplet manifold
|
||||||
@ -116,10 +113,8 @@ subroutine G0T0(doACFDT,exchange_kernel,doXBS,BSE,TDA,singlet_manifold,triplet_m
|
|||||||
|
|
||||||
! Compute linear response
|
! Compute linear response
|
||||||
|
|
||||||
call linear_response_pp(ispin,.true.,.false.,nBas,nC,nO,nV,nR, &
|
call linear_response_pp(ispin,.true.,.false.,nBas,nC,nO,nV,nR,nOOt,nVVt,eHF(:),ERI(:,:,:,:), &
|
||||||
nOOt,nVVt,eHF(:),ERI(:,:,:,:), &
|
Omega1t(:),X1t(:,:),Y1t(:,:),Omega2t(:),X2t(:,:),Y2t(:,:), &
|
||||||
Omega1t(:),X1t(:,:),Y1t(:,:), &
|
|
||||||
Omega2t(:),X2t(:,:),Y2t(:,:), &
|
|
||||||
EcRPA(ispin))
|
EcRPA(ispin))
|
||||||
|
|
||||||
EcRPA(ispin) = 3d0*EcRPA(ispin)
|
EcRPA(ispin) = 3d0*EcRPA(ispin)
|
||||||
@ -130,16 +125,12 @@ subroutine G0T0(doACFDT,exchange_kernel,doXBS,BSE,TDA,singlet_manifold,triplet_m
|
|||||||
! Compute excitation densities for the T-matrix
|
! Compute excitation densities for the T-matrix
|
||||||
|
|
||||||
call excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOOt,nVVt,ERI(:,:,:,:), &
|
call excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOOt,nVVt,ERI(:,:,:,:), &
|
||||||
X1t(:,:),Y1t(:,:),rho1t(:,:,:), &
|
X1t(:,:),Y1t(:,:),rho1t(:,:,:),X2t(:,:),Y2t(:,:),rho2t(:,:,:))
|
||||||
X2t(:,:),Y2t(:,:),rho2t(:,:,:))
|
|
||||||
|
|
||||||
!----------------------------------------------
|
!----------------------------------------------
|
||||||
! Compute T-matrix version of the self-energy
|
! Compute T-matrix version of the self-energy
|
||||||
!----------------------------------------------
|
!----------------------------------------------
|
||||||
|
|
||||||
rho1s = 0d0
|
|
||||||
rho1t = 0d0
|
|
||||||
|
|
||||||
call self_energy_Tmatrix_diag(eta,nBas,nC,nO,nV,nR,nOOs,nVVs,nOOt,nVVt,eHF(:), &
|
call self_energy_Tmatrix_diag(eta,nBas,nC,nO,nV,nR,nOOs,nVVs,nOOt,nVVt,eHF(:), &
|
||||||
Omega1s(:),rho1s(:,:,:),Omega2s(:),rho2s(:,:,:), &
|
Omega1s(:),rho1s(:,:,:),Omega2s(:),rho2s(:,:,:), &
|
||||||
Omega1t(:),rho1t(:,:,:),Omega2t(:),rho2t(:,:,:), &
|
Omega1t(:),rho1t(:,:,:),Omega2t(:),rho2t(:,:,:), &
|
||||||
|
@ -33,14 +33,21 @@ program QuAcK
|
|||||||
logical :: doXBS
|
logical :: doXBS
|
||||||
|
|
||||||
integer :: nShell
|
integer :: nShell
|
||||||
integer,allocatable :: TotAngMomShell(:),KShell(:)
|
integer,allocatable :: TotAngMomShell(:)
|
||||||
double precision,allocatable :: CenterShell(:,:),DShell(:,:),ExpShell(:,:)
|
integer,allocatable :: KShell(:)
|
||||||
|
double precision,allocatable :: CenterShell(:,:)
|
||||||
|
double precision,allocatable :: DShell(:,:)
|
||||||
|
double precision,allocatable :: ExpShell(:,:)
|
||||||
|
integer,allocatable :: max_ang_mom(:)
|
||||||
|
double precision,allocatable :: min_exponent(:,:)
|
||||||
|
double precision,allocatable :: max_exponent(:)
|
||||||
|
|
||||||
integer :: TrialType
|
integer :: TrialType
|
||||||
double precision,allocatable :: cTrial(:),gradient(:),hessian(:,:)
|
double precision,allocatable :: cTrial(:),gradient(:),hessian(:,:)
|
||||||
|
|
||||||
double precision,allocatable :: S(:,:),T(:,:),V(:,:),Hc(:,:),H(:,:),X(:,:)
|
double precision,allocatable :: S(:,:),T(:,:),V(:,:),Hc(:,:),H(:,:),X(:,:)
|
||||||
double precision,allocatable :: ERI_AO_basis(:,:,:,:),ERI_MO_basis(:,:,:,:)
|
double precision,allocatable :: ERI_AO_basis(:,:,:,:)
|
||||||
|
double precision,allocatable :: ERI_MO_basis(:,:,:,:)
|
||||||
double precision,allocatable :: F12(:,:,:,:),Yuk(:,:,:,:),FC(:,:,:,:,:,:)
|
double precision,allocatable :: F12(:,:,:,:),Yuk(:,:,:,:),FC(:,:,:,:,:,:)
|
||||||
|
|
||||||
double precision :: start_QuAcK ,end_QuAcK ,t_QuAcK
|
double precision :: start_QuAcK ,end_QuAcK ,t_QuAcK
|
||||||
@ -161,14 +168,16 @@ program QuAcK
|
|||||||
|
|
||||||
call read_geometry(nNuc,ZNuc,rNuc,ENuc)
|
call read_geometry(nNuc,ZNuc,rNuc,ENuc)
|
||||||
|
|
||||||
allocate(CenterShell(maxShell,ncart),TotAngMomShell(maxShell),KShell(maxShell), &
|
allocate(CenterShell(maxShell,ncart),TotAngMomShell(maxShell),KShell(maxShell),DShell(maxShell,maxK), &
|
||||||
DShell(maxShell,maxK),ExpShell(maxShell,maxK))
|
ExpShell(maxShell,maxK),max_ang_mom(nNuc),min_exponent(nNuc,maxL+1),max_exponent(nNuc))
|
||||||
|
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
! Read basis set information
|
! Read basis set information
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
|
|
||||||
call read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KShell,DShell,ExpShell)
|
call read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KShell,DShell,ExpShell, &
|
||||||
|
max_ang_mom,min_exponent,max_exponent)
|
||||||
nS(:) = (nO(:) - nC(:))*(nV(:) - nR(:))
|
nS(:) = (nO(:) - nC(:))*(nV(:) - nR(:))
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
@ -671,9 +680,9 @@ program QuAcK
|
|||||||
|
|
||||||
call cpu_time(start_G0T0)
|
call cpu_time(start_G0T0)
|
||||||
call soG0T0(eta,nBas,nC(1),nO(1),nV(1),nR(1),ENuc,ERHF,ERI_MO_basis,eHF)
|
call soG0T0(eta,nBas,nC(1),nO(1),nV(1),nR(1),ENuc,ERHF,ERI_MO_basis,eHF)
|
||||||
! call G0T0(doACFDT,exchange_kernel,doXBS,BSE,TDA, &
|
call G0T0(doACFDT,exchange_kernel,doXBS,BSE,TDA, &
|
||||||
! singlet_manifold,triplet_manifold,linGW,eta, &
|
singlet_manifold,triplet_manifold,linGW,eta, &
|
||||||
! nBas,nC(1),nO(1),nV(1),nR(1),nS(1),ENuc,ERHF,ERI_MO_basis,eHF)
|
nBas,nC(1),nO(1),nV(1),nR(1),nS(1),ENuc,ERHF,ERI_MO_basis,eHF)
|
||||||
|
|
||||||
call cpu_time(end_G0T0)
|
call cpu_time(end_G0T0)
|
||||||
|
|
||||||
|
@ -45,11 +45,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do c=nO+1,nBas-nR
|
do c=nO+1,nBas-nR
|
||||||
do d=c,nBas-nR
|
do d=c,nBas-nR
|
||||||
cd = cd + 1
|
cd = cd + 1
|
||||||
rho1(p,i,ab) = rho1(p,i,ab) &
|
rho1(p,i,ab) = rho1(p,i,ab) + ERI(p,i,c,d)*X1(cd,ab)
|
||||||
+ ERI(p,i,c,d)*X1(cd,ab)
|
|
||||||
! + (ERI(p,i,c,d) + ERI(p,i,d,c))*X1(cd,ab) &
|
|
||||||
! /sqrt((1d0 + Kronecker_delta(p,i))*(1d0 + Kronecker_delta(c,d)))
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -57,11 +53,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do k=nC+1,nO
|
do k=nC+1,nO
|
||||||
do l=k,nO
|
do l=k,nO
|
||||||
kl = kl + 1
|
kl = kl + 1
|
||||||
rho1(p,i,ab) = rho1(p,i,ab) &
|
rho1(p,i,ab) = rho1(p,i,ab) + ERI(p,i,k,l)*Y1(kl,ab)
|
||||||
+ ERI(p,i,k,l)*Y1(kl,ab)
|
|
||||||
! + (ERI(p,i,k,l) + ERI(p,i,l,k))*Y1(kl,ab) &
|
|
||||||
! /sqrt((1d0 + Kronecker_delta(p,i))*(1d0 + Kronecker_delta(k,l)))
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -75,11 +67,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do c=nO+1,nBas-nR
|
do c=nO+1,nBas-nR
|
||||||
do d=c,nBas-nR
|
do d=c,nBas-nR
|
||||||
cd = cd + 1
|
cd = cd + 1
|
||||||
rho2(p,a,ij) = rho2(p,a,ij) &
|
rho2(p,a,ij) = rho2(p,a,ij) + ERI(p,nO+a,c,d)*X2(cd,ij)
|
||||||
+ ERI(p,nO+a,c,d)*X2(cd,ij)
|
|
||||||
! + (ERI(p,nO+a,c,d) + ERI(p,nO+a,d,c))*X2(cd,ij) &
|
|
||||||
! /sqrt((1d0 + Kronecker_delta(p,nO+a))*(1d0 + Kronecker_delta(c,d)))
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -87,16 +75,13 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do k=nC+1,nO
|
do k=nC+1,nO
|
||||||
do l=k,nO
|
do l=k,nO
|
||||||
kl = kl + 1
|
kl = kl + 1
|
||||||
rho2(p,a,ij) = rho2(p,a,ij) &
|
rho2(p,a,ij) = rho2(p,a,ij) + ERI(p,nO+a,k,l)*Y2(kl,ij)
|
||||||
+ ERI(p,nO+a,k,l)*Y2(kl,ij)
|
|
||||||
! + (ERI(p,nO+a,k,l) + ERI(p,nO+a,l,k))*Y2(kl,ij) &
|
|
||||||
! /sqrt((1d0 + Kronecker_delta(p,nO+a))*(1d0 + Kronecker_delta(k,l)))
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end if
|
end if
|
||||||
@ -116,9 +101,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do c=nO+1,nBas-nR
|
do c=nO+1,nBas-nR
|
||||||
do d=c+1,nBas-nR
|
do d=c+1,nBas-nR
|
||||||
cd = cd + 1
|
cd = cd + 1
|
||||||
rho1(p,i,ab) = rho1(p,i,ab) &
|
rho1(p,i,ab) = rho1(p,i,ab) + (ERI(p,i,c,d) - ERI(p,i,d,c))*X1(cd,ab)
|
||||||
+ (ERI(p,i,c,d) - ERI(p,i,d,c))*X1(cd,ab)
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -126,8 +109,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do k=nC+1,nO
|
do k=nC+1,nO
|
||||||
do l=k+1,nO
|
do l=k+1,nO
|
||||||
kl = kl + 1
|
kl = kl + 1
|
||||||
rho1(p,i,ab) = rho1(p,i,ab) &
|
rho1(p,i,ab) = rho1(p,i,ab) + (ERI(p,i,k,l) - ERI(p,i,l,k))*Y1(kl,ab)
|
||||||
+ (ERI(p,i,k,l) - ERI(p,i,l,k))*Y1(kl,ab)
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -141,9 +123,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do c=nO+1,nBas-nR
|
do c=nO+1,nBas-nR
|
||||||
do d=c+1,nBas-nR
|
do d=c+1,nBas-nR
|
||||||
cd = cd + 1
|
cd = cd + 1
|
||||||
rho2(p,a,ij) = rho2(p,a,ij) &
|
rho2(p,a,ij) = rho2(p,a,ij) + (ERI(p,nO+a,c,d) - ERI(p,nO+a,d,c))*X2(cd,ij)
|
||||||
+ (ERI(p,nO+a,c,d) - ERI(p,nO+a,d,c))*X2(cd,ij)
|
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -151,13 +131,13 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do k=nC+1,nO
|
do k=nC+1,nO
|
||||||
do l=k+1,nO
|
do l=k+1,nO
|
||||||
kl = kl + 1
|
kl = kl + 1
|
||||||
rho2(p,a,ij) = rho2(p,a,ij) &
|
rho2(p,a,ij) = rho2(p,a,ij) + (ERI(p,nO+a,k,l) - ERI(p,nO+a,l,k))*Y2(kl,ij)
|
||||||
+ (ERI(p,nO+a,k,l) - ERI(p,nO+a,l,k))*Y2(kl,ij)
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end do
|
end do
|
||||||
|
|
||||||
end if
|
end if
|
||||||
@ -177,8 +157,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do c=nO+1,nBas-nR
|
do c=nO+1,nBas-nR
|
||||||
do d=c+1,nBas-nR
|
do d=c+1,nBas-nR
|
||||||
cd = cd + 1
|
cd = cd + 1
|
||||||
rho1(p,i,ab) = rho1(p,i,ab) &
|
rho1(p,i,ab) = rho1(p,i,ab) + (ERI(p,i,c,d) - ERI(p,i,d,c))*X1(cd,ab)
|
||||||
+ (ERI(p,i,c,d) - ERI(p,i,d,c))*X1(cd,ab)
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -186,8 +165,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do k=nC+1,nO
|
do k=nC+1,nO
|
||||||
do l=k+1,nO
|
do l=k+1,nO
|
||||||
kl = kl + 1
|
kl = kl + 1
|
||||||
rho1(p,i,ab) = rho1(p,i,ab) &
|
rho1(p,i,ab) = rho1(p,i,ab) + (ERI(p,i,k,l) - ERI(p,i,l,k))*Y1(kl,ab)
|
||||||
+ (ERI(p,i,k,l) - ERI(p,i,l,k))*Y1(kl,ab)
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -201,8 +179,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do c=nO+1,nBas-nR
|
do c=nO+1,nBas-nR
|
||||||
do d=c+1,nBas-nR
|
do d=c+1,nBas-nR
|
||||||
cd = cd + 1
|
cd = cd + 1
|
||||||
rho2(p,a,ij) = rho2(p,a,ij) &
|
rho2(p,a,ij) = rho2(p,a,ij) + (ERI(p,nO+a,c,d) - ERI(p,nO+a,d,c))*X2(cd,ij)
|
||||||
+ (ERI(p,nO+a,c,d) - ERI(p,nO+a,d,c))*X2(cd,ij)
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -210,8 +187,7 @@ subroutine excitation_density_Tmatrix(ispin,nBas,nC,nO,nV,nR,nOO,nVV,ERI,X1,Y1,r
|
|||||||
do k=nC+1,nO
|
do k=nC+1,nO
|
||||||
do l=k+1,nO
|
do l=k+1,nO
|
||||||
kl = kl + 1
|
kl = kl + 1
|
||||||
rho2(p,a,ij) = rho2(p,a,ij) &
|
rho2(p,a,ij) = rho2(p,a,ij) + (ERI(p,nO+a,k,l) - ERI(p,nO+a,l,k))*Y2(kl,ij)
|
||||||
+ (ERI(p,nO+a,k,l) - ERI(p,nO+a,l,k))*Y2(kl,ij)
|
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
|
||||||
|
@ -72,7 +72,7 @@ subroutine self_energy_Tmatrix_diag(eta,nBas,nC,nO,nV,nR,nOOs,nVVs,nOOt,nVVt,e,
|
|||||||
do i=nC+1,nO
|
do i=nC+1,nO
|
||||||
do cd=1,nVVt
|
do cd=1,nVVt
|
||||||
eps = e(p) + e(i) - Omega1t(cd)
|
eps = e(p) + e(i) - Omega1t(cd)
|
||||||
! SigT(p) = SigT(p) + rho1t(p,i,cd)*rho1t(p,i,cd)/eps
|
SigT(p) = SigT(p) + rho1t(p,i,cd)**2/eps
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
@ -83,7 +83,7 @@ subroutine self_energy_Tmatrix_diag(eta,nBas,nC,nO,nV,nR,nOOs,nVVs,nOOt,nVVt,e,
|
|||||||
do a=1,nV-nR
|
do a=1,nV-nR
|
||||||
do kl=1,nOOt
|
do kl=1,nOOt
|
||||||
eps = e(p) + e(nO+a) - Omega2t(kl)
|
eps = e(p) + e(nO+a) - Omega2t(kl)
|
||||||
! SigT(p) = SigT(p) + rho2t(p,a,kl)*rho2t(p,a,kl)/eps
|
SigT(p) = SigT(p) + rho2t(p,a,kl)**2/eps
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
@ -79,8 +79,8 @@ subroutine soG0T0(eta,nBas,nC,nO,nV,nR,ENuc,ERHF,ERI,eHF)
|
|||||||
|
|
||||||
! Compute linear response
|
! Compute linear response
|
||||||
|
|
||||||
call linear_response_pp(ispin,.true.,.false.,nBas2,nC2,nO2,nV2,nR2,nOO,nVV, &
|
call linear_response_pp(ispin,.true.,.false.,nBas2,nC2,nO2,nV2,nR2,nOO,nVV,seHF(:),sERI(:,:,:,:), &
|
||||||
seHF,sERI,Omega1,X1,Y1,Omega2,X2,Y2, &
|
Omega1(:),X1(:,:),Y1(:,:),Omega2(:),X2(:,:),Y2(:,:), &
|
||||||
EcRPA)
|
EcRPA)
|
||||||
|
|
||||||
call print_excitation('pp-RPA (N+2)',ispin,nVV,Omega1(:))
|
call print_excitation('pp-RPA (N+2)',ispin,nVV,Omega1(:))
|
||||||
@ -109,8 +109,8 @@ subroutine soG0T0(eta,nBas,nC,nO,nV,nR,ENuc,ERHF,ERI,eHF)
|
|||||||
! Solve the quasi-particle equation
|
! Solve the quasi-particle equation
|
||||||
!----------------------------------------------
|
!----------------------------------------------
|
||||||
|
|
||||||
! eG0T0(:) = seHF(:) + SigT(:)
|
eG0T0(:) = seHF(:) + SigT(:)
|
||||||
eG0T0(:) = seHF(:) + Z(:)*SigT(:)
|
! eG0T0(:) = seHF(:) + Z(:)*SigT(:)
|
||||||
|
|
||||||
!----------------------------------------------
|
!----------------------------------------------
|
||||||
! Dump results
|
! Dump results
|
||||||
|
@ -17,6 +17,9 @@ program eDFT
|
|||||||
double precision,allocatable :: CenterShell(:,:)
|
double precision,allocatable :: CenterShell(:,:)
|
||||||
double precision,allocatable :: DShell(:,:)
|
double precision,allocatable :: DShell(:,:)
|
||||||
double precision,allocatable :: ExpShell(:,:)
|
double precision,allocatable :: ExpShell(:,:)
|
||||||
|
integer,allocatable :: max_ang_mom(:)
|
||||||
|
double precision,allocatable :: min_exponent(:,:)
|
||||||
|
double precision,allocatable :: max_exponent(:)
|
||||||
|
|
||||||
double precision,allocatable :: S(:,:)
|
double precision,allocatable :: S(:,:)
|
||||||
double precision,allocatable :: T(:,:)
|
double precision,allocatable :: T(:,:)
|
||||||
@ -75,14 +78,15 @@ program eDFT
|
|||||||
|
|
||||||
call read_geometry(nNuc,ZNuc,rNuc,ENuc)
|
call read_geometry(nNuc,ZNuc,rNuc,ENuc)
|
||||||
|
|
||||||
allocate(CenterShell(maxShell,ncart),TotAngMomShell(maxShell),KShell(maxShell), &
|
allocate(CenterShell(maxShell,ncart),TotAngMomShell(maxShell),KShell(maxShell),DShell(maxShell,maxK), &
|
||||||
DShell(maxShell,maxK),ExpShell(maxShell,maxK))
|
ExpShell(maxShell,maxK),max_ang_mom(nNuc),min_exponent(nNuc,maxL+1),max_exponent(nNuc))
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
! Read basis set information
|
! Read basis set information
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
|
|
||||||
call read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KShell,DShell,ExpShell)
|
call read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KShell,DShell,ExpShell, &
|
||||||
|
max_ang_mom,min_exponent,max_exponent)
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
! DFT options
|
! DFT options
|
||||||
@ -131,7 +135,7 @@ program eDFT
|
|||||||
|
|
||||||
! Test numgrid
|
! Test numgrid
|
||||||
|
|
||||||
! call test_numgrid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,nRad,nAng,nGrid,root,weight)
|
call test_numgrid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent)
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
! Calculate AO values at grid points
|
! Calculate AO values at grid points
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
subroutine read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KShell,DShell,ExpShell)
|
subroutine read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KShell,DShell,ExpShell, &
|
||||||
|
max_ang_mom,min_exponent,max_exponent)
|
||||||
|
|
||||||
! Read basis set information
|
! Read basis set information
|
||||||
|
|
||||||
@ -24,6 +25,10 @@ subroutine read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KSh
|
|||||||
double precision,intent(out) :: DShell(maxShell,maxK),ExpShell(maxShell,maxK)
|
double precision,intent(out) :: DShell(maxShell,maxK),ExpShell(maxShell,maxK)
|
||||||
integer,intent(out) :: nV
|
integer,intent(out) :: nV
|
||||||
|
|
||||||
|
integer,intent(out) :: max_ang_mom(nNuc)
|
||||||
|
double precision,intent(out) :: min_exponent(nNuc,maxL+1)
|
||||||
|
double precision,intent(out) :: max_exponent(nNuc)
|
||||||
|
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
! Primary basis set information
|
! Primary basis set information
|
||||||
!------------------------------------------------------------------------
|
!------------------------------------------------------------------------
|
||||||
@ -37,17 +42,32 @@ subroutine read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KSh
|
|||||||
write(*,'(A28)') 'Gaussian basis set'
|
write(*,'(A28)') 'Gaussian basis set'
|
||||||
write(*,'(A28)') '------------------'
|
write(*,'(A28)') '------------------'
|
||||||
|
|
||||||
|
! Initailization
|
||||||
|
|
||||||
nShell = 0
|
nShell = 0
|
||||||
|
max_ang_mom(:) = 0
|
||||||
|
min_exponent(:,:) = huge(0d0)
|
||||||
|
max_exponent(:) = 0d0
|
||||||
|
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
! Loop over atoms
|
||||||
|
!------------------------------------------------------------------------
|
||||||
do i=1,nNuc
|
do i=1,nNuc
|
||||||
|
|
||||||
read(2,*) iNuc,nShAt
|
read(2,*) iNuc,nShAt
|
||||||
write(*,'(A28,1X,I16)') 'Atom n. ',iNuc
|
write(*,'(A28,1X,I16)') 'Atom n. ',iNuc
|
||||||
write(*,'(A28,1X,I16)') 'number of shells ',nShAt
|
write(*,'(A28,1X,I16)') 'number of shells ',nShAt
|
||||||
write(*,'(A28)') '------------------'
|
write(*,'(A28)') '------------------'
|
||||||
|
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
! Loop over shells
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
do j=1,nShAt
|
||||||
|
|
||||||
|
nShell = nShell + 1
|
||||||
|
|
||||||
! Basis function centers
|
! Basis function centers
|
||||||
|
|
||||||
do j=1,nShAt
|
|
||||||
nShell = nShell + 1
|
|
||||||
do k=1,ncart
|
do k=1,ncart
|
||||||
CenterShell(nShell,k) = rNuc(iNuc,k)
|
CenterShell(nShell,k) = rNuc(iNuc,k)
|
||||||
enddo
|
enddo
|
||||||
@ -55,28 +75,54 @@ subroutine read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KSh
|
|||||||
! Shell type and contraction degree
|
! Shell type and contraction degree
|
||||||
|
|
||||||
read(2,*) shelltype,KShell(nShell)
|
read(2,*) shelltype,KShell(nShell)
|
||||||
if(shelltype == "S") then
|
|
||||||
|
select case (shelltype)
|
||||||
|
case ("S")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 0
|
TotAngMomShell(nShell) = 0
|
||||||
write(*,'(A28,1X,I16)') 's-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 's-type shell with K = ',KShell(nShell)
|
||||||
elseif(shelltype == "P") then
|
|
||||||
|
case ("P")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 1
|
TotAngMomShell(nShell) = 1
|
||||||
write(*,'(A28,1X,I16)') 'p-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 'p-type shell with K = ',KShell(nShell)
|
||||||
elseif(shelltype == "D") then
|
|
||||||
|
case ("D")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 2
|
TotAngMomShell(nShell) = 2
|
||||||
write(*,'(A28,1X,I16)') 'd-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 'd-type shell with K = ',KShell(nShell)
|
||||||
elseif(shelltype == "F") then
|
|
||||||
|
case ("F")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 3
|
TotAngMomShell(nShell) = 3
|
||||||
write(*,'(A28,1X,I16)') 'f-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 'f-type shell with K = ',KShell(nShell)
|
||||||
elseif(shelltype == "G") then
|
|
||||||
|
case ("G")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 4
|
TotAngMomShell(nShell) = 4
|
||||||
write(*,'(A28,1X,I16)') 'g-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 'g-type shell with K = ',KShell(nShell)
|
||||||
elseif(shelltype == "H") then
|
|
||||||
|
case ("H")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 5
|
TotAngMomShell(nShell) = 5
|
||||||
write(*,'(A28,1X,I16)') 'h-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 'h-type shell with K = ',KShell(nShell)
|
||||||
elseif(shelltype == "I") then
|
|
||||||
|
case ("I")
|
||||||
|
|
||||||
TotAngMomShell(nShell) = 6
|
TotAngMomShell(nShell) = 6
|
||||||
write(*,'(A28,1X,I16)') 'i-type shell with K = ',KShell(nShell)
|
write(*,'(A28,1X,I16)') 'i-type shell with K = ',KShell(nShell)
|
||||||
endif
|
|
||||||
|
case ("J")
|
||||||
|
|
||||||
|
TotAngMomShell(nShell) = 7
|
||||||
|
write(*,'(A28,1X,I16)') 'j-type shell with K = ',KShell(nShell)
|
||||||
|
|
||||||
|
case default
|
||||||
|
|
||||||
|
call print_warning('!!! Angular momentum too high !!!')
|
||||||
|
stop
|
||||||
|
|
||||||
|
end select
|
||||||
|
|
||||||
! Read exponents and contraction coefficients
|
! Read exponents and contraction coefficients
|
||||||
|
|
||||||
@ -85,9 +131,30 @@ subroutine read_basis(nNuc,rNuc,nBas,nO,nV,nShell,TotAngMomShell,CenterShell,KSh
|
|||||||
read(2,*) kk,ExpShell(nShell,k),DShell(nShell,k)
|
read(2,*) kk,ExpShell(nShell,k),DShell(nShell,k)
|
||||||
write(*,'(A28,1X,F16.10,F16.10)') '',ExpShell(nShell,k),DShell(nShell,k)
|
write(*,'(A28,1X,F16.10,F16.10)') '',ExpShell(nShell,k),DShell(nShell,k)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
min_exponent(iNuc,TotAngMomShell(nShell)+1) &
|
||||||
|
= min(min_exponent(iNuc,TotAngMomShell(nShell)+1),minval(ExpShell(nShell,1:KShell(nShell))))
|
||||||
|
max_exponent(iNuc) = max(max_exponent(iNuc),maxval(ExpShell(nShell,:)))
|
||||||
|
max_ang_mom(iNuc) = max(max_ang_mom(iNuc),TotAngMomShell(nShell))
|
||||||
|
|
||||||
enddo
|
enddo
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
! End loop over shells
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
|
||||||
write(*,'(A28)') '------------------'
|
write(*,'(A28)') '------------------'
|
||||||
|
|
||||||
|
! print*,'maximum angular momemtum for atom n. ',iNuc,' = '
|
||||||
|
! print*,max_ang_mom(iNuc)
|
||||||
|
! print*,'maximum exponent for atom n. ',iNuc,' = '
|
||||||
|
! print*,max_exponent(iNuc)
|
||||||
|
! print*,'minimum exponent for atom n. ',iNuc,' = '
|
||||||
|
! print*,min_exponent(iNuc,1:max_ang_mom(iNuc)+1)
|
||||||
|
|
||||||
enddo
|
enddo
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
! End loop over atoms
|
||||||
|
!------------------------------------------------------------------------
|
||||||
|
|
||||||
! Total number of shells
|
! Total number of shells
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user