mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-10 13:08:23 +01:00
Add indent
This commit is contained in:
parent
db8f905b98
commit
a8eaf1cfb4
@ -1898,114 +1898,133 @@ end
|
|||||||
!!
|
!!
|
||||||
!! M_n(x) modified spherical bessel function
|
!! M_n(x) modified spherical bessel function
|
||||||
!!
|
!!
|
||||||
double precision function int_prod_bessel(l,gam,n,m,a,b,arg)
|
|
||||||
implicit none
|
|
||||||
integer n,k,m,q,l,kcp
|
|
||||||
double precision gam,dblefact,fact,pi,a,b
|
|
||||||
double precision int,intold,sum,coef_nk,crochet,u,int_prod_bessel_large,freal,arg
|
|
||||||
logical done
|
|
||||||
|
|
||||||
u=(a+b)/(2.d0*dsqrt(gam))
|
double precision function int_prod_bessel(l,gam,n,m,a,b,arg)
|
||||||
freal=dexp(-arg)
|
|
||||||
|
|
||||||
if(a.eq.0.d0.and.b.eq.0.d0)then
|
implicit none
|
||||||
if(n.ne.0.or.m.ne.0)then
|
integer n,k,m,q,l,kcp
|
||||||
int_prod_bessel=0.d0
|
double precision gam,dblefact,fact,pi,a,b
|
||||||
return
|
double precision int,intold,sum,coef_nk,crochet,u,int_prod_bessel_large,freal,arg
|
||||||
endif
|
logical done
|
||||||
int_prod_bessel=crochet(l,gam)*freal
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
if(u.gt.6.d0)then
|
u=(a+b)/(2.d0*dsqrt(gam))
|
||||||
int_prod_bessel=int_prod_bessel_large(l,gam,n,m,a,b,arg)
|
freal=dexp(-arg)
|
||||||
|
|
||||||
|
if(a.eq.0.d0.and.b.eq.0.d0)then
|
||||||
|
if(n.ne.0.or.m.ne.0)then
|
||||||
|
int_prod_bessel=0.d0
|
||||||
return
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
int_prod_bessel=crochet(l,gam)*freal
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
if(u.gt.6.d0)then
|
||||||
|
int_prod_bessel=int_prod_bessel_large(l,gam,n,m,a,b,arg)
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
if(a.ne.0.d0.and.b.ne.0.d0)then
|
||||||
|
|
||||||
|
q=0
|
||||||
|
intold=-1.d0
|
||||||
|
int=0.d0
|
||||||
|
done=.false.
|
||||||
|
kcp=0
|
||||||
|
|
||||||
|
do while (.not.done)
|
||||||
|
|
||||||
|
kcp=kcp+1
|
||||||
|
sum=0.d0
|
||||||
|
|
||||||
|
do k=0,q
|
||||||
|
sum=sum+coef_nk(n,k)*coef_nk(m,q-k)*a**(n+2*k)*b**(m-2*k+2*q)
|
||||||
|
enddo
|
||||||
|
|
||||||
|
int=int+sum*crochet(2*q+n+m+l,gam)
|
||||||
|
|
||||||
|
if(dabs(int-intold).lt.1d-15)then
|
||||||
|
done=.true.
|
||||||
|
else
|
||||||
|
|
||||||
|
q=q+1
|
||||||
|
intold=int
|
||||||
endif
|
endif
|
||||||
|
enddo
|
||||||
|
|
||||||
|
int_prod_bessel=int*freal
|
||||||
|
|
||||||
|
if(kcp.gt.100)then
|
||||||
|
print*,'**WARNING** bad convergence in int_prod_bessel'
|
||||||
|
endif
|
||||||
|
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
if(a.ne.0.d0.and.b.ne.0.d0)then
|
if(a.eq.0.d0.and.b.ne.0.d0)then
|
||||||
|
|
||||||
|
if(n.ne.0)then
|
||||||
|
int_prod_bessel=0.d0
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
q=0
|
q=0
|
||||||
intold=-1.d0
|
intold=-1.d0
|
||||||
int=0.d0
|
int=0.d0
|
||||||
done=.false.
|
done=.false.
|
||||||
kcp=0
|
kcp=0
|
||||||
do while (.not.done)
|
|
||||||
kcp=kcp+1
|
do while (.not.done)
|
||||||
sum=0.d0
|
|
||||||
do k=0,q
|
kcp=kcp+1
|
||||||
sum=sum+coef_nk(n,k)*coef_nk(m,q-k)*a**(n+2*k)*b**(m-2*k+2*q)
|
int=int+coef_nk(m,q)*b**(m+2*q)*crochet(2*q+m+l,gam)
|
||||||
enddo
|
|
||||||
int=int+sum*crochet(2*q+n+m+l,gam)
|
if(dabs(int-intold).lt.1d-15)then
|
||||||
if(dabs(int-intold).lt.1d-15)then
|
done=.true.
|
||||||
|
else
|
||||||
|
q=q+1
|
||||||
|
intold=int
|
||||||
|
endif
|
||||||
|
|
||||||
|
enddo
|
||||||
|
|
||||||
|
int_prod_bessel=int*freal
|
||||||
|
if(kcp.gt.100)stop '**WARNING** bad convergence in int_prod_bessel'
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
if(a.ne.0.d0.and.b.eq.0.d0)then
|
||||||
|
if(m.ne.0)then
|
||||||
|
int_prod_bessel=0.d0
|
||||||
|
return
|
||||||
|
endif
|
||||||
|
|
||||||
|
q=0
|
||||||
|
intold=-1.d0
|
||||||
|
int=0.d0
|
||||||
|
done=.false.
|
||||||
|
kcp=0
|
||||||
|
|
||||||
|
do while (.not.done)
|
||||||
|
kcp=kcp+1
|
||||||
|
int=int+coef_nk(n,q)*a**(n+2*q)*crochet(2*q+n+l,gam)
|
||||||
|
if(dabs(int-intold).lt.1d-15)then
|
||||||
done=.true.
|
done=.true.
|
||||||
else
|
else
|
||||||
q=q+1
|
q=q+1
|
||||||
intold=int
|
intold=int
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
int_prod_bessel=int*freal
|
|
||||||
if(kcp.gt.100)then
|
|
||||||
print*,'**WARNING** bad convergence in int_prod_bessel'
|
|
||||||
! else
|
|
||||||
! print*,'kcp=',kcp
|
|
||||||
endif
|
|
||||||
return
|
|
||||||
endif
|
endif
|
||||||
|
enddo
|
||||||
|
|
||||||
|
int_prod_bessel=int*freal
|
||||||
|
if(kcp.gt.100)stop '**WARNING** bad convergence in int_prod_bessel'
|
||||||
|
return
|
||||||
|
|
||||||
if(a.eq.0.d0.and.b.ne.0.d0)then
|
endif
|
||||||
if(n.ne.0)then
|
|
||||||
int_prod_bessel=0.d0
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
q=0
|
stop 'pb in int_prod_bessel!!'
|
||||||
intold=-1.d0
|
end
|
||||||
int=0.d0
|
|
||||||
done=.false.
|
|
||||||
kcp=0
|
|
||||||
do while (.not.done)
|
|
||||||
kcp=kcp+1
|
|
||||||
int=int+coef_nk(m,q)*b**(m+2*q)*crochet(2*q+m+l,gam)
|
|
||||||
if(dabs(int-intold).lt.1d-15)then
|
|
||||||
done=.true.
|
|
||||||
else
|
|
||||||
q=q+1
|
|
||||||
intold=int
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
int_prod_bessel=int*freal
|
|
||||||
if(kcp.gt.100)stop '**WARNING** bad convergence in int_prod_bessel'
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
if(a.ne.0.d0.and.b.eq.0.d0)then
|
|
||||||
if(m.ne.0)then
|
|
||||||
int_prod_bessel=0.d0
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
q=0
|
|
||||||
intold=-1.d0
|
|
||||||
int=0.d0
|
|
||||||
done=.false.
|
|
||||||
kcp=0
|
|
||||||
do while (.not.done)
|
|
||||||
kcp=kcp+1
|
|
||||||
int=int+coef_nk(n,q)*a**(n+2*q)*crochet(2*q+n+l,gam)
|
|
||||||
if(dabs(int-intold).lt.1d-15)then
|
|
||||||
done=.true.
|
|
||||||
else
|
|
||||||
q=q+1
|
|
||||||
intold=int
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
int_prod_bessel=int*freal
|
|
||||||
if(kcp.gt.100)stop '**WARNING** bad convergence in int_prod_bessel'
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
|
|
||||||
stop 'pb in int_prod_bessel!!'
|
|
||||||
end
|
|
||||||
|
|
||||||
double precision function int_prod_bessel_large(l,gam,n,m,a,b,arg)
|
double precision function int_prod_bessel_large(l,gam,n,m,a,b,arg)
|
||||||
implicit none
|
implicit none
|
||||||
|
@ -169,7 +169,7 @@ def run_hf(geo, basis, mult=1, pseudo=False, remove_after_sucess=True):
|
|||||||
|
|
||||||
ref_energy["sto-3g"]["methane"] = Energy(-39.7267433402, None)
|
ref_energy["sto-3g"]["methane"] = Energy(-39.7267433402, None)
|
||||||
ref_energy["vdz"]["SO2"] = Energy(None, -41.48912297776174)
|
ref_energy["vdz"]["SO2"] = Energy(None, -41.48912297776174)
|
||||||
ref_energy["vdz"]["HBO"] = Energy(None, -19.1198251160)
|
ref_energy["vdz"]["HBO"] = Energy(None, -19.11982540413317)
|
||||||
|
|
||||||
# ~#~#~#~#~#~#~#~#~#~#~#~#~#~#~ #
|
# ~#~#~#~#~#~#~#~#~#~#~#~#~#~#~ #
|
||||||
# G l o b a l _ v a r i a b l e #
|
# G l o b a l _ v a r i a b l e #
|
||||||
|
Loading…
Reference in New Issue
Block a user