10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-08 20:33:26 +01:00

Cleaned correlation_energy_ratio_max

This commit is contained in:
Anthony Scemama 2017-04-21 22:59:42 +02:00
parent 4dd50301f1
commit 23d7794109
4 changed files with 57 additions and 60 deletions

View File

@ -9,6 +9,15 @@ program fci_zmq
allocate (pt2(N_states)) allocate (pt2(N_states))
double precision :: hf_energy_ref
logical :: has
call ezfio_has_hartree_fock_energy(has)
if (has) then
call ezfio_get_hartree_fock_energy(hf_energy_ref)
else
hf_energy_ref = ref_bitmask_energy
endif
pt2 = 1.d0 pt2 = 1.d0
threshold_davidson_in = threshold_davidson threshold_davidson_in = threshold_davidson
threshold_davidson = threshold_davidson_in * 100.d0 threshold_davidson = threshold_davidson_in * 100.d0
@ -41,10 +50,23 @@ program fci_zmq
print*,'Beginning the selection ...' print*,'Beginning the selection ...'
E_CI_before(1:N_states) = CI_energy(1:N_states) E_CI_before(1:N_states) = CI_energy(1:N_states)
do while ( (N_det < N_det_max) .and. (maxval(abs(pt2(1:N_states))) > pt2_max) ) double precision :: correlation_energy_ratio
correlation_energy_ratio = E_CI_before(1) - hf_energy_ref
correlation_energy_ratio = correlation_energy_ratio / (correlation_energy_ratio + pt2(1))
do while ( &
(N_det < N_det_max) .and. &
(maxval(abs(pt2(1:N_states))) > pt2_max) .and. &
(correlation_energy_ratio < correlation_energy_ratio_max) &
)
correlation_energy_ratio = E_CI_before(1) - hf_energy_ref
correlation_energy_ratio = correlation_energy_ratio / (correlation_energy_ratio + pt2(1))
print *, 'N_det = ', N_det print *, 'N_det = ', N_det
print *, 'N_states = ', N_states print *, 'N_states = ', N_states
print*, 'correlation_ratio = ', correlation_energy_ratio
do k=1, N_states do k=1, N_states
print*,'State ',k print*,'State ',k
print *, 'PT2 = ', pt2(k) print *, 'PT2 = ', pt2(k)

View File

@ -10,11 +10,14 @@ program fci_zmq
allocate (pt2(N_states)) allocate (pt2(N_states))
IF (correlation_energy_ratio_max .NE. 1.d0) THEN double precision :: hf_energy_ref
logical :: has
DOUBLE PRECISION :: hf_energy_ref call ezfio_has_hartree_fock_energy(has)
CALL ezfio_get_hartree_fock_energy(hf_energy_ref) if (has) then
END IF call ezfio_get_hartree_fock_energy(hf_energy_ref)
else
hf_energy_ref = ref_bitmask_energy
endif
pt2 = 1.d0 pt2 = 1.d0
threshold_davidson_in = threshold_davidson threshold_davidson_in = threshold_davidson
@ -47,28 +50,22 @@ program fci_zmq
E_CI_before(1:N_states) = CI_energy(1:N_states) E_CI_before(1:N_states) = CI_energy(1:N_states)
n_det_before = 0 n_det_before = 0
double precision :: correlation_energy_ratio
correlation_energy_ratio = E_CI_before(1) - hf_energy_ref
correlation_energy_ratio = correlation_energy_ratio / (correlation_energy_ratio + pt2(1))
do while ( (N_det < N_det_max) .and. (maxval(abs(pt2(1:N_states))) > pt2_max) ) do while ( &
(N_det < N_det_max) .and. &
(maxval(abs(pt2(1:N_states))) > pt2_max) .and. &
IF (correlation_energy_ratio_max .NE. 1.d0) THEN (correlation_energy_ratio < correlation_energy_ratio_max) &
DOUBLE PRECISION :: correlation_energy_var, correlation_energy_var_ratio )
correlation_energy_var = MAXVAL(E_CI_before) - hf_energy_ref
correlation_energy_var_ratio = correlation_energy_var / (correlation_energy_var + MAXVAL(pt2(:)))
IF (correlation_energy_ratio_max < correlation_energy_var_ratio) THEN
EXIT
ENDIF
ENDIF
correlation_energy_ratio = E_CI_before(1) - hf_energy_ref
correlation_energy_ratio = correlation_energy_ratio / (correlation_energy_ratio + pt2(1))
print *, 'N_det = ', N_det print *, 'N_det = ', N_det
print *, 'N_states = ', N_states print *, 'N_states = ', N_states
IF (correlation_energy_ratio_max .NE. 1.d0) THEN print*, 'correlation_ratio = ', correlation_energy_ratio
print*, 'correlation_ratio = ', correlation_energy_var
ENDIF
do k=1, N_states do k=1, N_states
print*,'State ',k print*,'State ',k
@ -76,6 +73,7 @@ program fci_zmq
print *, 'E = ', CI_energy(k) print *, 'E = ', CI_energy(k)
print *, 'E(before)+PT2 = ', E_CI_before(k)+pt2(k) print *, 'E(before)+PT2 = ', E_CI_before(k)+pt2(k)
enddo enddo
print *, '-----' print *, '-----'
if(N_states.gt.1)then if(N_states.gt.1)then
print*,'Variational Energy difference' print*,'Variational Energy difference'
@ -130,8 +128,8 @@ program fci_zmq
double precision :: relative_error double precision :: relative_error
relative_error=1.d-3 relative_error=1.d-3
pt2 = 0.d0 pt2 = 0.d0
call ZMQ_pt2(pt2,relative_error) call ZMQ_pt2(pt2,relative_error) ! Stochastic PT2
!call ZMQ_selection(0, pt2)! pour non-stochastic !call ZMQ_selection(0, pt2) ! Deterministic PT2
print *, 'Final step' print *, 'Final step'
print *, 'N_det = ', N_det print *, 'N_det = ', N_det
print *, 'N_states = ', N_states print *, 'N_states = ', N_states

View File

@ -11,17 +11,10 @@ doc: The selection process stops when the largest PT2 (for all the state) is low
interface: ezfio,provider,ocaml interface: ezfio,provider,ocaml
default: 0.0001 default: 0.0001
[var_pt2_ratio]
type: Normalized_float
doc: The selection process stops when the energy ratio variational/(variational+PT2)
is equal to var_pt2_ratio. (Obsolete. Need to be removed)
interface: ezfio,provider,ocaml
default: 0.75
[correlation_energy_ratio_max] [correlation_energy_ratio_max]
type: Normalized_float type: Normalized_float
doc: The selection process stops at a fixed correlation ratio (usefull for getting same accuracy between molecules) doc: The selection process stops at a fixed correlation ratio (useful for getting same accuracy between molecules)
Defined as (E_CI-E_HF)/ (E_CI+PT2 - E_HF) If Ratio eq 1 it will not be used. (E_HF) is not required. Defined as (E_CI-E_HF)/ (E_CI+PT2 - E_HF). (E_HF) is not required.
interface: ezfio,provider,ocaml interface: ezfio,provider,ocaml
default: 1.00 default: 1.00

View File

@ -234,30 +234,14 @@ double precision function dble_logfact(n) result(logfact2)
! n!! ! n!!
END_DOC END_DOC
integer :: n integer :: n
double precision, save :: memo(1:100) integer :: k
integer, save :: memomax = 1 double precision :: prod
prod=0.d0
ASSERT (iand(n,1) /= 0) do k=2,n,2
if (n<=memomax) then prod=prod+dlog(dfloat(k))
if (n<3) then enddo
logfact2 = 0.d0 logfact2=prod
else
logfact2 = memo(n)
endif
return return
endif
integer :: i
memo(1) = 0.d0
do i=memomax+2,min(n,99),2
memo(i) = memo(i-2)+ dlog(dble(i))
enddo
memomax = min(n,99)
logfact2 = memo(memomax)
do i=101,n,2
logfact2 += dlog(dble(i))
enddo
end function end function