mirror of
https://gitlab.com/scemama/eplf
synced 2025-01-05 11:00:17 +01:00
Acceleration
This commit is contained in:
parent
dc47a48108
commit
da570c030f
9
Makefile
9
Makefile
@ -1,16 +1,17 @@
|
|||||||
# MPI-ifort
|
# MPI-ifort
|
||||||
IRPF90 = irpf90 -DMPI #-a -d
|
IRPF90 = irpf90 -DMPI #-a -d
|
||||||
FC = mpif90 -static-intel -static-libgcc -xT
|
FC = mpif90 -static-intel -static-libgcc -xT
|
||||||
FCFLAGS= -O3 -g
|
FCFLAGS= -O3
|
||||||
|
|
||||||
# Gfortran
|
# Gfortran
|
||||||
#FC = gfortran -ffree-line-length-none -static-libgcc -static
|
#FC = gfortran -ffree-line-length-none -static-libgcc -static
|
||||||
#FCFLAGS= -O3 -ffast-math -L ~/QCIO/lib
|
#FCFLAGS= -O3 -ffast-math -L ~/QCIO/lib
|
||||||
|
|
||||||
# Mono
|
# Mono
|
||||||
#IRPF90 = irpf90
|
IRPF90 = irpf90
|
||||||
#FC = ifort -static-intel -static-libgcc
|
FC = ifort -static-intel -static-libgcc
|
||||||
#FCFLAGS= -O3 -axP
|
FCFLAGS= -O3 -axP
|
||||||
|
FCFLAGS= -O3 -xT -g
|
||||||
|
|
||||||
SRC=
|
SRC=
|
||||||
OBJ=
|
OBJ=
|
||||||
|
69
Util.irp.f
69
Util.irp.f
@ -1,38 +1,16 @@
|
|||||||
|
|
||||||
double precision function Boys(x,n)
|
recursive double precision function Boys(x,n) result(res)
|
||||||
implicit none
|
implicit none
|
||||||
include 'constants.F'
|
include 'constants.F'
|
||||||
|
|
||||||
real, intent(in) :: x
|
real, intent(in) :: x
|
||||||
integer, intent(in) :: n
|
integer, intent(in) :: n
|
||||||
|
|
||||||
integer :: k
|
ASSERT (x > 0.)
|
||||||
|
|
||||||
real, parameter :: thr = 6.
|
|
||||||
integer ,parameter :: Nmax = 20
|
|
||||||
|
|
||||||
double precision :: fact,fact2
|
|
||||||
|
|
||||||
if (n == 0) then
|
if (n == 0) then
|
||||||
if (x > thr) then
|
res = sqrt(pi/(4.*x))*erf(sqrt(x))
|
||||||
Boys = 0.5d0*sqrt(pi/x)
|
|
||||||
else
|
|
||||||
Boys = 1.d0/dble(2*n+1)
|
|
||||||
do k=1,Nmax
|
|
||||||
Boys = Boys + (-x)**k/dble(fact(k)*(2*n+2*k+1))
|
|
||||||
enddo
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
else
|
else
|
||||||
if (x > thr) then
|
res = (dble(2*n-1) * Boys(x,(n-1)) - exp(-x) )/(2.*x)
|
||||||
Boys = fact2(2*n-1)*0.5d0**(n+1)*sqrt(pi/x**(2*n+1))
|
|
||||||
else
|
|
||||||
Boys = 1.d0/dble(2*n+1)
|
|
||||||
do k=1,Nmax
|
|
||||||
Boys = Boys + (-x)**k/dble(fact(k)*(2*n+2*k+1))
|
|
||||||
enddo
|
|
||||||
endif
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
end function
|
end function
|
||||||
@ -96,3 +74,42 @@ double precision function fact(n)
|
|||||||
end function
|
end function
|
||||||
|
|
||||||
|
|
||||||
|
double precision function rintgauss(n)
|
||||||
|
implicit none
|
||||||
|
include 'constants.F'
|
||||||
|
|
||||||
|
integer :: n
|
||||||
|
|
||||||
|
rintgauss = sqrt(pi)
|
||||||
|
if ( n == 0 ) then
|
||||||
|
return
|
||||||
|
else if ( n == 1 ) then
|
||||||
|
rintgauss = 0.
|
||||||
|
else if ( mod(n,2) == 1) then
|
||||||
|
rintgauss = 0.
|
||||||
|
else
|
||||||
|
double precision :: fact2
|
||||||
|
rintgauss = rintgauss/(2.**(n/2))
|
||||||
|
rintgauss = rintgauss * fact2(n-1)
|
||||||
|
endif
|
||||||
|
end function
|
||||||
|
|
||||||
|
double precision function goverlap(gamA,gamB,nA)
|
||||||
|
implicit none
|
||||||
|
|
||||||
|
real :: gamA, gamB
|
||||||
|
integer :: nA(3)
|
||||||
|
|
||||||
|
double precision :: gamtot
|
||||||
|
gamtot = gamA+gamB
|
||||||
|
|
||||||
|
goverlap=1.0
|
||||||
|
|
||||||
|
integer :: l
|
||||||
|
double precision :: rintgauss
|
||||||
|
do l=1,3
|
||||||
|
goverlap = goverlap * rintgauss(nA(l)+nA(l))/ (gamtot**(0.5+float(nA(l))))
|
||||||
|
enddo
|
||||||
|
|
||||||
|
end function
|
||||||
|
|
||||||
|
44
ao.irp.f
44
ao.irp.f
@ -123,10 +123,10 @@ END_PROVIDER
|
|||||||
!$OMP END CRITICAL (qcio_critical)
|
!$OMP END CRITICAL (qcio_critical)
|
||||||
|
|
||||||
double precision :: norm, norm2
|
double precision :: norm, norm2
|
||||||
double precision :: overlap
|
double precision :: goverlap
|
||||||
do i=1,ao_num
|
do i=1,ao_num
|
||||||
do j=1,ao_prim_num(i)
|
do j=1,ao_prim_num(i)
|
||||||
norm = overlap(ao_expo(j,i),ao_expo(j,i),ao_power(i,:))
|
norm = goverlap(ao_expo(j,i),ao_expo(j,i),ao_power(i,:))
|
||||||
norm = sqrt(norm)
|
norm = sqrt(norm)
|
||||||
ao_coef(j,i) = buffer(j,i)/norm
|
ao_coef(j,i) = buffer(j,i)/norm
|
||||||
enddo
|
enddo
|
||||||
@ -134,43 +134,3 @@ END_PROVIDER
|
|||||||
|
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
double precision function rintgauss(n)
|
|
||||||
implicit none
|
|
||||||
|
|
||||||
integer :: n
|
|
||||||
double precision :: pi
|
|
||||||
pi = acos(-1.)
|
|
||||||
|
|
||||||
rintgauss = sqrt(pi)
|
|
||||||
if ( n == 0 ) then
|
|
||||||
return
|
|
||||||
else if ( n == 1 ) then
|
|
||||||
rintgauss = 0.
|
|
||||||
else if ( mod(n,2) == 1) then
|
|
||||||
rintgauss = 0.
|
|
||||||
else
|
|
||||||
double precision :: fact2
|
|
||||||
rintgauss = rintgauss/(2.**(n/2))
|
|
||||||
rintgauss = rintgauss * fact2(n-1)
|
|
||||||
endif
|
|
||||||
end function
|
|
||||||
|
|
||||||
double precision function overlap(gamA,gamB,nA)
|
|
||||||
implicit none
|
|
||||||
|
|
||||||
real :: gamA, gamB
|
|
||||||
integer :: nA(3)
|
|
||||||
|
|
||||||
double precision :: gamtot
|
|
||||||
gamtot = gamA+gamB
|
|
||||||
|
|
||||||
overlap=1.0
|
|
||||||
|
|
||||||
integer :: l
|
|
||||||
double precision :: rintgauss
|
|
||||||
do l=1,3
|
|
||||||
overlap = overlap * rintgauss(nA(l)+nA(l))/ (gamtot**(0.5+float(nA(l))))
|
|
||||||
enddo
|
|
||||||
|
|
||||||
end function
|
|
||||||
|
|
||||||
|
39
eplf.irp.f
39
eplf.irp.f
@ -3,7 +3,7 @@ BEGIN_PROVIDER [ real, eplf_gamma ]
|
|||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Value of the gaussian for the EPLF
|
! Value of the gaussian for the EPLF
|
||||||
END_DOC
|
END_DOC
|
||||||
eplf_gamma = 10.
|
eplf_gamma = 10000.
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, ao_eplf_integral_matrix, (ao_num,ao_num) ]
|
BEGIN_PROVIDER [ double precision, ao_eplf_integral_matrix, (ao_num,ao_num) ]
|
||||||
@ -27,27 +27,33 @@ BEGIN_PROVIDER [ double precision, mo_eplf_integral_matrix, (mo_num,mo_num) ]
|
|||||||
! Array of all the <chi_i chi_j | exp(-gamma r^2)> for EPLF
|
! Array of all the <chi_i chi_j | exp(-gamma r^2)> for EPLF
|
||||||
END_DOC
|
END_DOC
|
||||||
integer :: i, j, k, l
|
integer :: i, j, k, l
|
||||||
|
double precision :: t
|
||||||
PROVIDE ao_eplf_integral_matrix
|
PROVIDE ao_eplf_integral_matrix
|
||||||
PROVIDE mo_coef
|
PROVIDE mo_coef
|
||||||
do i=1,mo_num
|
do i=1,mo_num
|
||||||
do j=i,mo_num
|
do j=i,mo_num
|
||||||
mo_eplf_integral_matrix(j,i) = 0.
|
mo_eplf_integral_matrix(j,i) = 0.
|
||||||
enddo
|
enddo
|
||||||
enddo
|
|
||||||
|
|
||||||
do i=1,mo_num
|
|
||||||
do k=1,ao_num
|
do k=1,ao_num
|
||||||
if (mo_coef(k,i) /= 0.) then
|
if (abs(mo_coef(k,i)) /= 0.) then
|
||||||
do j=i,mo_num
|
do l=1,ao_num
|
||||||
do l=1,ao_num
|
t = mo_coef(k,i)*ao_eplf_integral_matrix(l,k)
|
||||||
mo_eplf_integral_matrix(j,i) = mo_eplf_integral_matrix(j,i) + &
|
if (abs(ao_eplf_integral_matrix(l,k))>1.d-16) then
|
||||||
mo_coef(k,i)*mo_coef(l,j)*ao_eplf_integral_matrix(l,k)
|
do j=i,mo_num
|
||||||
enddo
|
mo_eplf_integral_matrix(j,i) = mo_eplf_integral_matrix(j,i) + &
|
||||||
enddo
|
t*mo_coef_transp(j,l)
|
||||||
endif
|
enddo
|
||||||
|
endif
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
do j=i,mo_num
|
enddo
|
||||||
|
|
||||||
|
do i=1,mo_num
|
||||||
|
do j=i+1,mo_num
|
||||||
mo_eplf_integral_matrix(i,j) = mo_eplf_integral_matrix(j,i)
|
mo_eplf_integral_matrix(i,j) = mo_eplf_integral_matrix(j,i)
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
@ -132,7 +138,7 @@ double precision function ao_eplf_integral_primitive_oneD_numeric(a,xa,i,b,xb,j,
|
|||||||
real, intent(in) :: a,b,gmma ! Exponents
|
real, intent(in) :: a,b,gmma ! Exponents
|
||||||
real, intent(in) :: xa,xb,xr ! Centers
|
real, intent(in) :: xa,xb,xr ! Centers
|
||||||
integer, intent(in) :: i,j ! Powers of xa and xb
|
integer, intent(in) :: i,j ! Powers of xa and xb
|
||||||
integer,parameter :: Npoints=1000
|
integer,parameter :: Npoints=10000
|
||||||
real :: x, xmin, xmax, dx
|
real :: x, xmin, xmax, dx
|
||||||
|
|
||||||
ASSERT (a>0.)
|
ASSERT (a>0.)
|
||||||
@ -165,12 +171,13 @@ double precision function ao_eplf_integral_numeric(i,j,gmma,center)
|
|||||||
integer :: p,q,k
|
integer :: p,q,k
|
||||||
double precision :: integral
|
double precision :: integral
|
||||||
double precision :: ao_eplf_integral_primitive_oneD_numeric
|
double precision :: ao_eplf_integral_primitive_oneD_numeric
|
||||||
real :: gmma, center(3)
|
real :: gmma, center(3), c
|
||||||
|
|
||||||
|
|
||||||
ao_eplf_integral_numeric = 0.
|
ao_eplf_integral_numeric = 0.
|
||||||
do q=1,ao_prim_num(j)
|
do q=1,ao_prim_num(j)
|
||||||
do p=1,ao_prim_num(i)
|
do p=1,ao_prim_num(i)
|
||||||
|
c = ao_coef(p,i)*ao_coef(q,j)
|
||||||
integral = &
|
integral = &
|
||||||
ao_eplf_integral_primitive_oneD_numeric( &
|
ao_eplf_integral_primitive_oneD_numeric( &
|
||||||
ao_expo(p,i), &
|
ao_expo(p,i), &
|
||||||
@ -199,7 +206,7 @@ double precision function ao_eplf_integral_numeric(i,j,gmma,center)
|
|||||||
ao_power(j,3), &
|
ao_power(j,3), &
|
||||||
gmma, &
|
gmma, &
|
||||||
center(3))
|
center(3))
|
||||||
ao_eplf_integral_numeric = ao_eplf_integral_numeric + integral*ao_coef(p,i)*ao_coef(q,j)
|
ao_eplf_integral_numeric = ao_eplf_integral_numeric + c*integral
|
||||||
enddo
|
enddo
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ double precision function primitive_overlap_oneD_numeric(a,xa,i,b,xb,j)
|
|||||||
real, intent(in) :: a,b ! Exponents
|
real, intent(in) :: a,b ! Exponents
|
||||||
real, intent(in) :: xa,xb ! Centers
|
real, intent(in) :: xa,xb ! Centers
|
||||||
integer, intent(in) :: i,j ! Powers of xa and xb
|
integer, intent(in) :: i,j ! Powers of xa and xb
|
||||||
integer,parameter :: Npoints=1000
|
integer,parameter :: Npoints=10000
|
||||||
real :: x, xmin, xmax, dx
|
real :: x, xmin, xmax, dx
|
||||||
|
|
||||||
ASSERT (a>0.)
|
ASSERT (a>0.)
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
program debug
|
program debug
|
||||||
PROVIDE ao_prim_num_max
|
PROVIDE ao_prim_num_max
|
||||||
read(*,*) eplf_gamma
|
!read(*,*) eplf_gamma
|
||||||
TOUCH eplf_gamma
|
!TOUCH eplf_gamma
|
||||||
call run()
|
call run()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user