mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-03 10:05:57 +01:00
Multi-state PT2
This commit is contained in:
parent
a290736145
commit
cd3c13077a
@ -29,10 +29,10 @@ size: (full_ci_zmq.n_iter)
|
|||||||
interface: ezfio
|
interface: ezfio
|
||||||
doc: The energy without a pt2 correction for n_det
|
doc: The energy without a pt2 correction for n_det
|
||||||
type: double precision
|
type: double precision
|
||||||
size: (full_ci_zmq.n_iter)
|
size: (full_ci_zmq.n_iter,determinants.n_states)
|
||||||
|
|
||||||
[pt2_iter]
|
[pt2_iter]
|
||||||
interface: ezfio
|
interface: ezfio
|
||||||
doc: The pt2 correction for n_det
|
doc: The pt2 correction for n_det
|
||||||
type: double precision
|
type: double precision
|
||||||
size: (full_ci_zmq.n_iter)
|
size: (full_ci_zmq.n_iter,determinants.n_states)
|
||||||
|
@ -6,15 +6,17 @@ subroutine dump_fci_iterations_value(n_determinants,energy,pt2)
|
|||||||
! BEGIN_DOC
|
! BEGIN_DOC
|
||||||
!! Output the number of determinants, energy, and pt2 correction at each iteration
|
!! Output the number of determinants, energy, and pt2 correction at each iteration
|
||||||
! END_DOC
|
! END_DOC
|
||||||
integer :: n_determinants
|
integer, intent(in) :: n_determinants
|
||||||
double precision :: energy, pt2
|
double precision, intent(in) :: energy(N_states), pt2(N_states)
|
||||||
integer :: N_iterations
|
integer :: N_iterations
|
||||||
integer, allocatable :: n_determinants_list(:)
|
integer, allocatable :: n_determinants_list(:)
|
||||||
double precision, allocatable :: energy_list(:)
|
double precision, allocatable :: energy_list(:,:)
|
||||||
double precision, allocatable :: pt2_list(:)
|
double precision, allocatable :: pt2_list(:,:)
|
||||||
integer :: saveMethod
|
integer :: saveMethod
|
||||||
logical :: hasIter
|
logical :: hasIter
|
||||||
logical,save :: firstAccess=.TRUE. !! every update of firstAccess will be saved
|
logical,save :: firstAccess=.TRUE. !! every update of firstAccess will be saved
|
||||||
|
double precision, allocatable :: extrapolated_energy(:,:)
|
||||||
|
integer :: i,k
|
||||||
|
|
||||||
!!! Check to ensure that we should save iterations (default is Append)
|
!!! Check to ensure that we should save iterations (default is Append)
|
||||||
! saveMethod: 1==Append, 2==Overwrite, 3==NoSave
|
! saveMethod: 1==Append, 2==Overwrite, 3==NoSave
|
||||||
@ -42,16 +44,17 @@ subroutine dump_fci_iterations_value(n_determinants,energy,pt2)
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
!! Now allocate the array for entire size needed
|
!! Now allocate the array for entire size needed
|
||||||
|
allocate(extrapolated_energy(N_iterations+1,N_states))
|
||||||
allocate(n_determinants_list(N_iterations+1))
|
allocate(n_determinants_list(N_iterations+1))
|
||||||
allocate(energy_list(N_iterations+1))
|
allocate(energy_list(N_states,N_iterations+1))
|
||||||
allocate(pt2_list(N_iterations+1))
|
allocate(pt2_list(N_states,N_iterations+1))
|
||||||
|
|
||||||
!!! Pull previously written data
|
!!! Pull previously written data
|
||||||
!!! Unless it is at the beginning of a new/restarted calculation
|
!!! Unless it is at the beginning of a new/restarted calculation
|
||||||
if((hasIter).AND.(N_iterations>0)) then
|
if((hasIter).AND.(N_iterations>0)) then
|
||||||
call ezfio_get_full_ci_zmq_n_det_iter(n_determinants_list(1:N_iterations))
|
call ezfio_get_full_ci_zmq_n_det_iter(n_determinants_list)
|
||||||
call ezfio_get_full_ci_zmq_energy_iter(energy_list(1:N_iterations))
|
call ezfio_get_full_ci_zmq_energy_iter(energy_list)
|
||||||
call ezfio_get_full_ci_zmq_pt2_iter(pt2_list(1:N_iterations))
|
call ezfio_get_full_ci_zmq_pt2_iter(pt2_list)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
!! Now increment to the current iteration
|
!! Now increment to the current iteration
|
||||||
@ -59,8 +62,29 @@ subroutine dump_fci_iterations_value(n_determinants,energy,pt2)
|
|||||||
|
|
||||||
!! Add the data from latest iteration
|
!! Add the data from latest iteration
|
||||||
n_determinants_list(N_iterations) = n_determinants
|
n_determinants_list(N_iterations) = n_determinants
|
||||||
energy_list(N_iterations) = energy
|
energy_list(:,N_iterations) = energy(:)
|
||||||
pt2_list(N_iterations) = pt2
|
pt2_list(:,N_iterations) = pt2(:)
|
||||||
|
|
||||||
|
print *, 'Extrapolation'
|
||||||
|
print *, '============='
|
||||||
|
|
||||||
|
do i=1,N_states
|
||||||
|
call extrapolate_data(N_iterations, energy_list(i,1:N_iterations), pt2_list(i,1:N_iterations), extrapolated_energy(1:N_iterations,i))
|
||||||
|
enddo
|
||||||
|
|
||||||
|
do i=1,N_states
|
||||||
|
print *, 'State ', i
|
||||||
|
print *, '------------------'
|
||||||
|
print *, ''
|
||||||
|
write(*,*) '=========== ', '==================='
|
||||||
|
write(*,*) 'minimum PT2 ', 'Extrapolated energy'
|
||||||
|
write(*,*) '=========== ', '==================='
|
||||||
|
do k=2,min(N_iterations,8)
|
||||||
|
write(*,'(F11.4,2X,F18.8)') pt2_list(i,N_iterations+1-k), extrapolated_energy(k,i)
|
||||||
|
enddo
|
||||||
|
write(*,*) '=========== ', '==================='
|
||||||
|
enddo
|
||||||
|
|
||||||
|
|
||||||
! Reset the iteration number
|
! Reset the iteration number
|
||||||
call ezfio_set_full_ci_zmq_n_iter(N_iterations)
|
call ezfio_set_full_ci_zmq_n_iter(N_iterations)
|
||||||
@ -74,10 +98,11 @@ subroutine dump_fci_iterations_value(n_determinants,energy,pt2)
|
|||||||
deallocate(n_determinants_list)
|
deallocate(n_determinants_list)
|
||||||
deallocate(energy_list)
|
deallocate(energy_list)
|
||||||
deallocate(pt2_list)
|
deallocate(pt2_list)
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
!!! set first access to false
|
!!! set first access to false
|
||||||
!!! it will be saved
|
!!! it will be saved
|
||||||
firstAccess=.FALSE.
|
firstAccess=.FALSE.
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
@ -45,7 +45,7 @@ program fci_zmq
|
|||||||
print *, 'E+PT2 = ', CI_energy(k) + pt2(k)
|
print *, 'E+PT2 = ', CI_energy(k) + pt2(k)
|
||||||
print *, '-----'
|
print *, '-----'
|
||||||
enddo
|
enddo
|
||||||
call dump_fci_iterations_value(N_det,CI_energy(1),pt2(1)) ! This call automatically appends data
|
call dump_fci_iterations_value(N_det,CI_energy,pt2) ! This call automatically appends data
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
@ -89,6 +89,7 @@ program fci_zmq
|
|||||||
correlation_energy_ratio = min(1.d0,correlation_energy_ratio)
|
correlation_energy_ratio = min(1.d0,correlation_energy_ratio)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
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
|
print*, 'correlation_ratio = ', correlation_energy_ratio
|
||||||
@ -115,6 +116,8 @@ program fci_zmq
|
|||||||
(CI_energy(i)+ pt2(i) - (CI_energy(1) + pt2(1))) * 27.2107362681d0
|
(CI_energy(i)+ pt2(i) - (CI_energy(1) + pt2(1))) * 27.2107362681d0
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
|
call ezfio_set_full_ci_zmq_energy_pt2(CI_energy(1)+pt2(1))
|
||||||
|
call dump_fci_iterations_value(N_det,CI_energy,pt2)
|
||||||
|
|
||||||
n_det_before = N_det
|
n_det_before = N_det
|
||||||
to_select = N_det
|
to_select = N_det
|
||||||
@ -132,8 +135,6 @@ program fci_zmq
|
|||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
||||||
call ezfio_set_full_ci_zmq_energy_pt2(CI_energy(1)+pt2(1))
|
|
||||||
call dump_fci_iterations_value(N_det,CI_energy(1),pt2(1)) ! This call automatically appends data
|
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -142,8 +143,7 @@ program fci_zmq
|
|||||||
call diagonalize_CI
|
call diagonalize_CI
|
||||||
call save_wavefunction
|
call save_wavefunction
|
||||||
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
||||||
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
call ezfio_set_full_ci_zmq_energy_pt2(CI_energy(1)+pt2(1))
|
||||||
call dump_fci_iterations_value(N_det,CI_energy(1),pt2(1)) ! This call automatically appends data
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if (do_pt2) then
|
if (do_pt2) then
|
||||||
@ -157,7 +157,6 @@ program fci_zmq
|
|||||||
SOFT_TOUCH threshold_selectors threshold_generators
|
SOFT_TOUCH threshold_selectors threshold_generators
|
||||||
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
call ezfio_set_full_ci_zmq_energy(CI_energy(1))
|
||||||
call ezfio_set_full_ci_zmq_energy_pt2(CI_energy(1)+pt2(1))
|
call ezfio_set_full_ci_zmq_energy_pt2(CI_energy(1)+pt2(1))
|
||||||
call dump_fci_iterations_value(N_det,CI_energy(1),pt2(1)) ! This call automatically appends data
|
|
||||||
endif
|
endif
|
||||||
print *, 'N_det = ', N_det
|
print *, 'N_det = ', N_det
|
||||||
print *, 'N_states = ', N_states
|
print *, 'N_states = ', N_states
|
||||||
@ -171,6 +170,8 @@ program fci_zmq
|
|||||||
enddo
|
enddo
|
||||||
|
|
||||||
print *, '-----'
|
print *, '-----'
|
||||||
|
call dump_fci_iterations_value(N_det,CI_energy,pt2)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
@ -102,7 +102,7 @@ subroutine ZMQ_pt2(E, pt2,relative_error, absolute_error, error)
|
|||||||
!$OMP PRIVATE(i)
|
!$OMP PRIVATE(i)
|
||||||
i = omp_get_thread_num()
|
i = omp_get_thread_num()
|
||||||
if (i==0) then
|
if (i==0) then
|
||||||
call pt2_collector(E(pt2_stoch_istate), b, tbc, comb, Ncomb, computed, pt2_detail, sumabove, sum2above, Nabove, relative_error, absolute_error,w,error)
|
call pt2_collector(E(pt2_stoch_istate), b, tbc, comb, Ncomb, computed, pt2_detail, sumabove, sum2above, Nabove, relative_error, absolute_error, w, error)
|
||||||
pt2(pt2_stoch_istate) = w(pt2_stoch_istate)
|
pt2(pt2_stoch_istate) = w(pt2_stoch_istate)
|
||||||
else
|
else
|
||||||
call pt2_slave_inproc(i)
|
call pt2_slave_inproc(i)
|
||||||
|
Loading…
Reference in New Issue
Block a user