mirror of
https://github.com/QuantumPackage/qp2.git
synced 2025-01-08 20:33:20 +01:00
Merge pull request #160 from v1j4y/fix_ncsf
Fixed and verfied bug in n_CSF for Benzene singlet. #158
This commit is contained in:
commit
0bdfef3947
@ -1,9 +1,15 @@
|
|||||||
BEGIN_PROVIDER [ integer, NSOMOMax]
|
real*8 function lgamma(x)
|
||||||
&BEGIN_PROVIDER [ integer, NCSFMax]
|
implicit none
|
||||||
&BEGIN_PROVIDER [ integer*8, NMO]
|
real*8, intent(in) :: x
|
||||||
&BEGIN_PROVIDER [ integer, NBFMax]
|
lgamma = log(abs(gamma(x)))
|
||||||
&BEGIN_PROVIDER [ integer, n_CSF]
|
end function lgamma
|
||||||
&BEGIN_PROVIDER [ integer, maxDetDimPerBF]
|
|
||||||
|
BEGIN_PROVIDER [ integer, NSOMOMax]
|
||||||
|
&BEGIN_PROVIDER [ integer, NCSFMax]
|
||||||
|
&BEGIN_PROVIDER [ integer*8, NMO]
|
||||||
|
&BEGIN_PROVIDER [ integer, NBFMax]
|
||||||
|
&BEGIN_PROVIDER [ integer, n_CSF]
|
||||||
|
&BEGIN_PROVIDER [ integer, maxDetDimPerBF]
|
||||||
implicit none
|
implicit none
|
||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Documentation for NSOMOMax
|
! Documentation for NSOMOMax
|
||||||
@ -22,28 +28,67 @@
|
|||||||
integer NSOMO
|
integer NSOMO
|
||||||
integer dimcsfpercfg
|
integer dimcsfpercfg
|
||||||
integer detDimperBF
|
integer detDimperBF
|
||||||
real*8 :: coeff
|
real*8 :: coeff, binom1, binom2
|
||||||
integer MS
|
integer MS
|
||||||
integer ncfgpersomo
|
integer ncfgpersomo
|
||||||
|
real*8, external :: lgamma
|
||||||
detDimperBF = 0
|
detDimperBF = 0
|
||||||
MS = elec_alpha_num-elec_beta_num
|
MS = elec_alpha_num-elec_beta_num
|
||||||
! number of cfgs = number of dets for 0 somos
|
! number of cfgs = number of dets for 0 somos
|
||||||
n_CSF = 0
|
n_CSF = 0
|
||||||
ncfgprev = cfg_seniority_index(0)
|
ncfgprev = cfg_seniority_index(0)
|
||||||
|
ncfgpersomo = ncfgprev
|
||||||
|
do i = 1, elec_num
|
||||||
|
print *,"i=",i," Ncfg= ",cfg_seniority_index(i)
|
||||||
|
enddo
|
||||||
do i = iand(MS,1), NSOMOMax-2,2
|
do i = iand(MS,1), NSOMOMax-2,2
|
||||||
|
if(cfg_seniority_index(i) .EQ. -1) then
|
||||||
|
cycle
|
||||||
|
endif
|
||||||
if(cfg_seniority_index(i+2) .EQ. -1) then
|
if(cfg_seniority_index(i+2) .EQ. -1) then
|
||||||
ncfgpersomo = N_configuration + 1
|
ncfgpersomo = N_configuration + 1
|
||||||
else
|
else
|
||||||
ncfgpersomo = cfg_seniority_index(i+2)
|
if(cfg_seniority_index(i+2) > ncfgpersomo) then
|
||||||
|
ncfgpersomo = cfg_seniority_index(i+2)
|
||||||
|
else
|
||||||
|
k = 0
|
||||||
|
do while(cfg_seniority_index(i+2+k) < ncfgpersomo)
|
||||||
|
k = k + 2
|
||||||
|
ncfgpersomo = cfg_seniority_index(i+2+k)
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
endif
|
endif
|
||||||
ncfg = ncfgpersomo - ncfgprev
|
ncfg = ncfgpersomo - ncfgprev
|
||||||
if(iand(MS,1) .EQ. 0) then
|
if(iand(MS,1) .EQ. 0) then
|
||||||
dimcsfpercfg = max(1,nint((binom(i,i/2)-binom(i,i/2+1))))
|
!dimcsfpercfg = max(1,nint((binom(i,i/2)-binom(i,i/2+1))))
|
||||||
|
binom1 = dexp(lgamma(1.0d0*(i+1)) &
|
||||||
|
- lgamma(1.0d0*((i/2)+1)) &
|
||||||
|
- lgamma(1.0d0*(i-((i/2))+1)));
|
||||||
|
binom2 = dexp(lgamma(1.0d0*(i+1)) &
|
||||||
|
- lgamma(1.0d0*(((i/2)+1)+1)) &
|
||||||
|
- lgamma(1.0d0*(i-((i/2)+1)+1)));
|
||||||
|
dimcsfpercfg = max(1,nint(binom1 - binom2))
|
||||||
else
|
else
|
||||||
dimcsfpercfg = max(1,nint((binom(i,(i+1)/2)-binom(i,(i+3)/2))))
|
!dimcsfpercfg = max(1,nint((binom(i,(i+1)/2)-binom(i,(i+3)/2))))
|
||||||
|
binom1 = dexp(lgamma(1.0d0*(i+1)) &
|
||||||
|
- lgamma(1.0d0*(((i+1)/2)+1)) &
|
||||||
|
- lgamma(1.0d0*(i-(((i+1)/2))+1)));
|
||||||
|
binom2 = dexp(lgamma(1.0d0*(i+1)) &
|
||||||
|
- lgamma(1.0d0*((((i+3)/2)+1)+1)) &
|
||||||
|
- lgamma(1.0d0*(i-(((i+3)/2)+1)+1)));
|
||||||
|
dimcsfpercfg = max(1,nint(binom1 - binom2))
|
||||||
endif
|
endif
|
||||||
n_CSF += ncfg * dimcsfpercfg
|
n_CSF += ncfg * dimcsfpercfg
|
||||||
ncfgprev = cfg_seniority_index(i+2)
|
print *,"i=",i," ncfg= ", ncfg, " dims=", dimcsfpercfg, " n_csf=", n_CSF, ncfgpersomo, ncfgprev
|
||||||
|
if(cfg_seniority_index(i+2) > ncfgprev) then
|
||||||
|
ncfgprev = cfg_seniority_index(i+2)
|
||||||
|
else
|
||||||
|
k = 0
|
||||||
|
do while(cfg_seniority_index(i+2+k) < ncfgprev)
|
||||||
|
k = k + 2
|
||||||
|
ncfgprev = cfg_seniority_index(i+2+k)
|
||||||
|
enddo
|
||||||
|
endif
|
||||||
enddo
|
enddo
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user