mirror of
https://github.com/LCPQ/quantum_package
synced 2024-10-02 22:41:00 +02:00
Merge pull request #1 from madgal/madgal-patch-1
Added/Updated files to save iterations
This commit is contained in:
commit
365aab3acb
@ -8,4 +8,31 @@ type: double precision
|
|||||||
doc: Calculated FCI energy + PT2
|
doc: Calculated FCI energy + PT2
|
||||||
interface: ezfio
|
interface: ezfio
|
||||||
|
|
||||||
|
[iterative]
|
||||||
|
type:logical
|
||||||
|
doc: Save the data at each iteration:
|
||||||
|
interface: ezfio,ocaml
|
||||||
|
default:.False.
|
||||||
|
|
||||||
|
[n_iter]
|
||||||
|
interface: ezfio
|
||||||
|
doc: number of iterations
|
||||||
|
type:integer
|
||||||
|
|
||||||
|
[n_det_iter]
|
||||||
|
interface: ezfio
|
||||||
|
doc: number of determinants at iteration
|
||||||
|
type: integer
|
||||||
|
size: (full_ci_zmq.n_iter)
|
||||||
|
|
||||||
|
[energy_iter]
|
||||||
|
interface: ezfio
|
||||||
|
doc: The energy without a pt2 correction for n_det
|
||||||
|
type: double precision
|
||||||
|
size: (full_ci_zmq.n_iter)
|
||||||
|
|
||||||
|
[energyBefore_pt2_iter]
|
||||||
|
interface: ezfio
|
||||||
|
doc: The energy with pt2 correction for n_det
|
||||||
|
type: double precision
|
||||||
|
size: (full_ci_zmq.n_iter)
|
||||||
|
73
plugins/Full_CI_ZMQ/fci_iterations.irp.f
Normal file
73
plugins/Full_CI_ZMQ/fci_iterations.irp.f
Normal file
@ -0,0 +1,73 @@
|
|||||||
|
subroutine fci_iterations(n_determinants,energy,pt2)
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
! Output the number of determinants, energy, and pt2 correction at each iteration
|
||||||
|
END_DOC
|
||||||
|
integer :: n_determinants
|
||||||
|
double precision :: energy, pt2,E_before
|
||||||
|
integer :: N_iterations
|
||||||
|
integer, allocatable :: n_determinants_list(:)
|
||||||
|
double precision, allocatable :: energy_list(:)
|
||||||
|
double precision, allocatable :: energy_pt2_list(:)
|
||||||
|
logical :: saveIterations, hasIter
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
!!! CHECK TO ENSURE THAT WE SHOULD SAVE ITERATIONS (DEFAULT IS FALSE)
|
||||||
|
call ezfio_get_full_ci_zmq_iterative(saveIterations)
|
||||||
|
if (saveIterations) then
|
||||||
|
|
||||||
|
|
||||||
|
!!! If THE ITERATION IS PAST 1
|
||||||
|
!!! GET THE ITERATION NUMBER
|
||||||
|
!!! MAKE SURE THE CALCULATION IS ALSO NOT STARTING FROM SCRATCH
|
||||||
|
call ezfio_has_full_ci_zmq_n_iter(hasIter)
|
||||||
|
if((hasIter).AND.(n_determinants>1)) then
|
||||||
|
call ezfio_get_full_ci_zmq_n_iter(N_iterations)
|
||||||
|
else
|
||||||
|
N_iterations = 0
|
||||||
|
E_before =0
|
||||||
|
endif
|
||||||
|
|
||||||
|
!! NOW ALLOCATE THE ARRAY FOR ENTIRE SIZE NEEDED
|
||||||
|
!! BUT FIRST CHECK TO ENSURE IT IS NOT STARTING FROM SCRATCH BY CHECKING IF THE NUM DETERMINANTS HAS INCREASED
|
||||||
|
allocate(n_determinants_list(N_iterations+1))
|
||||||
|
allocate(energy_list(N_iterations+1))
|
||||||
|
allocate(energy_pt2_list(N_iterations+1))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
!!! PULL PREVIOUSLY WRITTEN DATA
|
||||||
|
!!! UNLESS ITS A NEW CALCULATION
|
||||||
|
if((hasIter).AND.(n_determinants>1)) then
|
||||||
|
call ezfio_get_full_ci_zmq_n_det_iter(n_determinants_list(1:N_iterations))
|
||||||
|
call ezfio_get_full_ci_zmq_energy_iter(energy_list(1:N_iterations))
|
||||||
|
E_before = energy_list(N_iterations)
|
||||||
|
call ezfio_get_full_ci_zmq_energyBefore_pt2_iter(energy_pt2_list(1:N_iterations))
|
||||||
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
!! NOW INCREMENT TO THE CURRENT ITERATION
|
||||||
|
N_iterations = N_iterations+1
|
||||||
|
|
||||||
|
|
||||||
|
!! ADD THE DATA FROM LATEST ITERATION
|
||||||
|
n_determinants_list(N_iterations) = n_determinants
|
||||||
|
energy_list(N_iterations) = energy
|
||||||
|
energy_pt2_list(N_iterations) = E_before +pt2
|
||||||
|
|
||||||
|
! RESET THE ITERATION NUMBER
|
||||||
|
call ezfio_set_full_ci_zmq_n_iter(N_iterations)
|
||||||
|
|
||||||
|
!!!! NOW RESET THE EZFIO VALUES
|
||||||
|
!!!! TO INCLUDE THE LATEST DATA
|
||||||
|
call ezfio_set_full_ci_zmq_n_det_iter(n_determinants_list)
|
||||||
|
call ezfio_set_full_ci_zmq_energy_iter(energy_list)
|
||||||
|
call ezfio_set_full_ci_zmq_energyBefore_pt2_iter(energy_pt2_list)
|
||||||
|
|
||||||
|
deallocate(n_determinants_list)
|
||||||
|
deallocate(energy_list)
|
||||||
|
deallocate(energy_pt2_list)
|
||||||
|
|
||||||
|
endif
|
||||||
|
end subroutine
|
@ -25,6 +25,8 @@ program fci_zmq
|
|||||||
hf_energy_ref = ref_bitmask_energy
|
hf_energy_ref = ref_bitmask_energy
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
!!!!! THIS CALL IS NOT AUTOMATIC
|
||||||
|
call fci_iterations(N_det,CI_energy(1),pt2(1))
|
||||||
if (N_det > N_det_max) then
|
if (N_det > N_det_max) then
|
||||||
psi_det = psi_det_sorted
|
psi_det = psi_det_sorted
|
||||||
psi_coef = psi_coef_sorted
|
psi_coef = psi_coef_sorted
|
||||||
@ -41,6 +43,8 @@ program fci_zmq
|
|||||||
print *, 'E+PT2 = ', CI_energy(k) + pt2(k)
|
print *, 'E+PT2 = ', CI_energy(k) + pt2(k)
|
||||||
print *, '-----'
|
print *, '-----'
|
||||||
enddo
|
enddo
|
||||||
|
!!!!! THIS CALL IS NOT AUTOMATIC
|
||||||
|
call fci_iterations(N_det,CI_energy(1),pt2(1))
|
||||||
endif
|
endif
|
||||||
double precision :: E_CI_before(N_states)
|
double precision :: E_CI_before(N_states)
|
||||||
|
|
||||||
@ -108,6 +112,8 @@ 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))
|
||||||
|
!!!!! THIS CALL IS NOT AUTOMATIC
|
||||||
|
call fci_iterations(N_det,CI_energy(1),pt2(1))
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -116,6 +122,8 @@ 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))
|
||||||
|
!!!!! THIS CALL IS NOT AUTOMATIC
|
||||||
|
call fci_iterations(N_det,CI_energy(1),pt2(1))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
if(do_pt2_end)then
|
if(do_pt2_end)then
|
||||||
@ -149,6 +157,8 @@ program fci_zmq
|
|||||||
enddo
|
enddo
|
||||||
call ezfio_set_full_ci_zmq_energy(E_CI_before(1))
|
call ezfio_set_full_ci_zmq_energy(E_CI_before(1))
|
||||||
call ezfio_set_full_ci_zmq_energy_pt2(E_CI_before(1)+pt2(1))
|
call ezfio_set_full_ci_zmq_energy_pt2(E_CI_before(1)+pt2(1))
|
||||||
|
!!!!! THIS CALL IS NOT AUTOMATIC
|
||||||
|
call fci_iterations(N_det,CI_energy(1),pt2(1))
|
||||||
endif
|
endif
|
||||||
|
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user