mirror of
https://github.com/pfloos/quack
synced 2025-01-03 10:05:49 +01:00
numgrid works
This commit is contained in:
parent
f6323a55e4
commit
1e65d1cf1f
@ -1,4 +1,5 @@
|
||||
subroutine allocate_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent,nGrid)
|
||||
subroutine allocate_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent, &
|
||||
radial_precision,nRad,nAng,nGrid)
|
||||
|
||||
! Allocate quadrature grid with numgrid (Radovan Bast)
|
||||
|
||||
@ -22,11 +23,14 @@ subroutine allocate_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_m
|
||||
double precision,intent(in) :: min_exponent(nNuc,maxL+1)
|
||||
double precision,intent(in) :: max_exponent(nNuc)
|
||||
|
||||
double precision :: radial_precision
|
||||
integer,intent(in) :: nRad
|
||||
integer,intent(in) :: nAng
|
||||
|
||||
! Local variables
|
||||
|
||||
integer :: iNuc
|
||||
|
||||
double precision :: radial_precision
|
||||
integer :: min_num_angular_points
|
||||
integer :: max_num_angular_points
|
||||
integer :: num_points
|
||||
@ -40,9 +44,8 @@ subroutine allocate_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_m
|
||||
|
||||
! Set useful variables
|
||||
|
||||
radial_precision = 1d-12
|
||||
min_num_angular_points = 6 ! SG-0
|
||||
max_num_angular_points = 170 ! SG-3
|
||||
min_num_angular_points = nAng
|
||||
max_num_angular_points = nAng
|
||||
|
||||
! Get total number of grid points
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
subroutine build_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent, &
|
||||
nGrid,weight,root)
|
||||
radial_precision,nRad,nAng,nGrid,weight,root)
|
||||
|
||||
! Compute quadrature grid with numgrid (Radovan Bast)
|
||||
|
||||
@ -23,6 +23,9 @@ subroutine build_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,
|
||||
double precision,intent(in) :: min_exponent(nNuc,maxL+1)
|
||||
double precision,intent(in) :: max_exponent(nNuc)
|
||||
|
||||
double precision,intent(in) :: radial_precision
|
||||
integer,intent(in) :: nRad
|
||||
integer,intent(in) :: nAng
|
||||
integer,intent(in) :: nGrid
|
||||
|
||||
! Local variables
|
||||
@ -30,7 +33,6 @@ subroutine build_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,
|
||||
integer :: iNuc
|
||||
integer :: iG
|
||||
|
||||
double precision :: radial_precision
|
||||
integer :: min_num_angular_points
|
||||
integer :: max_num_angular_points
|
||||
integer :: num_points
|
||||
@ -45,9 +47,8 @@ subroutine build_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,
|
||||
|
||||
! Set useful variables
|
||||
|
||||
radial_precision = 1d-12
|
||||
min_num_angular_points = 6 ! SG-0
|
||||
max_num_angular_points = 170 ! SG-3
|
||||
min_num_angular_points = nAng
|
||||
max_num_angular_points = nAng
|
||||
|
||||
!------------------------------------------------------------------------
|
||||
! Main loop over atoms
|
||||
@ -76,7 +77,7 @@ subroutine build_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,
|
||||
rNuc(:,3), &
|
||||
int(ZNuc(:)), &
|
||||
root(1,iG+1:num_points), &
|
||||
root(3,iG+1:num_points), &
|
||||
root(2,iG+1:num_points), &
|
||||
root(3,iG+1:num_points), &
|
||||
weight(iG+1:num_points) )
|
||||
|
||||
|
@ -32,10 +32,15 @@ program eDFT
|
||||
character(len=7) :: method
|
||||
integer :: x_rung,c_rung
|
||||
character(len=12) :: x_DFA ,c_DFA
|
||||
|
||||
integer :: SGn
|
||||
integer :: nRad,nAng,nGrid
|
||||
double precision :: radial_precision
|
||||
integer :: nRad
|
||||
integer :: nAng
|
||||
integer :: nGrid
|
||||
double precision,allocatable :: root(:,:)
|
||||
double precision,allocatable :: weight(:)
|
||||
|
||||
double precision,allocatable :: AO(:,:)
|
||||
double precision,allocatable :: dAO(:,:,:)
|
||||
|
||||
@ -128,14 +133,16 @@ program eDFT
|
||||
!------------------------------------------------------------------------
|
||||
! Construct quadrature grid
|
||||
!------------------------------------------------------------------------
|
||||
! call read_grid(SGn,nRad,nAng,nGrid)
|
||||
call read_grid(SGn,nRad,nAng,nGrid)
|
||||
radial_precision = 1d-7
|
||||
|
||||
call allocate_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent,nGrid)
|
||||
call allocate_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent, &
|
||||
radial_precision,nRad,nAng,nGrid)
|
||||
|
||||
allocate(root(ncart,nGrid),weight(nGrid))
|
||||
|
||||
call build_grid(nNuc,ZNuc,rNuc,nShell,TotAngMomShell,ExpShell,max_ang_mom,min_exponent,max_exponent, &
|
||||
nGrid,weight,root)
|
||||
radial_precision,nRad,nAng,nGrid,weight,root)
|
||||
|
||||
! call quadrature_grid(nRad,nAng,nGrid,root,weight)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user