mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-08 20:33:26 +01:00
pt2 slave
This commit is contained in:
parent
5f21ec66e2
commit
6881056eaf
@ -18,7 +18,7 @@ IRPF90_FLAGS : --ninja --align=32
|
||||
# 0 : Deactivate
|
||||
#
|
||||
[OPTION]
|
||||
MODE : DEBUG ; [ OPT | PROFILE | DEBUG ] : Chooses the section below
|
||||
MODE : OPT ; [ OPT | PROFILE | DEBUG ] : Chooses the section below
|
||||
CACHE : 1 ; Enable cache_compile.py
|
||||
OPENMP : 1 ; Append OpenMP flags
|
||||
|
||||
|
@ -104,87 +104,6 @@ program fci_zmq
|
||||
call save_wavefunction
|
||||
end
|
||||
|
||||
! subroutine ZMQ_pt2(pt2)
|
||||
! use f77_zmq
|
||||
! use selection_types
|
||||
!
|
||||
! implicit none
|
||||
!
|
||||
! character*(1000000) :: task
|
||||
! integer(ZMQ_PTR) :: zmq_to_qp_run_socket
|
||||
! type(selection_buffer) :: b
|
||||
! integer :: i, N
|
||||
! integer, external :: omp_get_thread_num
|
||||
! double precision, intent(out) :: pt2(N_states)
|
||||
!
|
||||
! integer*8, allocatable :: bulk(:), tirage(:)
|
||||
! integer, allocatable :: todo(:)
|
||||
! double precision, allocatable :: pt2_detail(:,:), val(:,:), weight(:)
|
||||
! double precision :: sume, sume2
|
||||
! double precision :: tot_n
|
||||
!
|
||||
! allocate(bulk(N_det), tirage(N_det), todo(0:N_det), pt2_detail(N_states, N_det), val(N_states, N_det))
|
||||
!
|
||||
! sume = 0d0
|
||||
! sume2 = 0d0
|
||||
! tot_n = 0d0
|
||||
! bulk = 0
|
||||
! tirage = 0
|
||||
! todo = 0
|
||||
!
|
||||
!
|
||||
! N = 1
|
||||
! provide nproc
|
||||
! provide ci_electronic_energy
|
||||
! call new_parallel_job(zmq_to_qp_run_socket,"pt2")
|
||||
! call zmq_put_psi(zmq_to_qp_run_socket,1,ci_electronic_energy,size(ci_electronic_energy))
|
||||
! call zmq_set_running(zmq_to_qp_run_socket)
|
||||
! call create_selection_buffer(N, N*2, b)
|
||||
!
|
||||
! integer :: i_generator, i_generator_end, generator_per_task, step
|
||||
!
|
||||
! integer :: mergeN
|
||||
! mergeN = 100
|
||||
! call get_carlo_workbatch(tirage, weight, todo, bulk, 1d-2, mergeN)
|
||||
! print *, "CARLO", todo(0), mergeN
|
||||
!
|
||||
! generator_per_task = todo(0)/1000 + 1
|
||||
! do i=1,todo(0),generator_per_task
|
||||
! i_generator_end = min(i+generator_per_task-1, todo(0))
|
||||
! print *, "TASK", (i_generator_end-i+1), todo(i:i_generator_end)
|
||||
! write(task,*) (i_generator_end-i+1), todo(i:i_generator_end)
|
||||
! call add_task_to_taskserver(zmq_to_qp_run_socket,task)
|
||||
! end do
|
||||
! print *, "tasked"
|
||||
! pt2_detail = 0d0
|
||||
! !$OMP PARALLEL DEFAULT(shared) SHARED(b, pt2) PRIVATE(i) NUM_THREADS(nproc+1)
|
||||
! i = omp_get_thread_num()
|
||||
! if (i==0) then
|
||||
! call pt2_collector(b, pt2_detail)
|
||||
! else
|
||||
! call pt2_slave_inproc(i)
|
||||
! endif
|
||||
! !$OMP END PARALLEL
|
||||
! call end_parallel_job(zmq_to_qp_run_socket, 'pt2')
|
||||
! print *, "daune"
|
||||
! val += pt2_detail
|
||||
! call perform_carlo(tirage, weight, bulk, val, sume, sume2, mergeN)
|
||||
! tot_n = 0
|
||||
! double precision :: sweight
|
||||
! sweight = 0d0
|
||||
! do i=1,N_det
|
||||
! if(weight(i) /= 0) tot_n = tot_n + dfloat(bulk(i))
|
||||
! sweight += weight(i)
|
||||
! end do
|
||||
! print *, "PT2_DETAIL", tot_n, sume/tot_n, sume, sume2
|
||||
! pt2 = 0d0
|
||||
! do i=1,N_det
|
||||
! if(weight(i) /= 0d0) exit
|
||||
! pt2(:) += pt2_detail(:,i)
|
||||
! end do
|
||||
! print *, "N_determinist = ", i-1
|
||||
! end subroutine
|
||||
|
||||
|
||||
subroutine ZMQ_pt2(pt2)
|
||||
use f77_zmq
|
||||
@ -192,16 +111,16 @@ subroutine ZMQ_pt2(pt2)
|
||||
|
||||
implicit none
|
||||
|
||||
character*(1000000) :: task
|
||||
character*(512) :: task
|
||||
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
|
||||
type(selection_buffer) :: b
|
||||
integer, external :: omp_get_thread_num
|
||||
double precision, intent(out) :: pt2(N_states)
|
||||
|
||||
|
||||
double precision :: pt2_detail(N_states, N_det_generators), comb(100000)
|
||||
logical :: computed(N_det_generators)
|
||||
integer :: tbc(0:N_det_generators)
|
||||
double precision, allocatable :: pt2_detail(:,:), comb(:)
|
||||
logical, allocatable :: computed(:)
|
||||
integer, allocatable :: tbc(:)
|
||||
integer :: i, Ncomb, generator_per_task, i_generator_end
|
||||
integer, external :: pt2_find
|
||||
|
||||
@ -209,7 +128,7 @@ subroutine ZMQ_pt2(pt2)
|
||||
double precision, external :: omp_get_wtime
|
||||
double precision :: time0, time
|
||||
|
||||
|
||||
allocate(pt2_detail(N_states, N_det_generators), comb(100000), computed(N_det_generators), tbc(0:N_det_generators))
|
||||
provide nproc
|
||||
|
||||
call random_seed()
|
||||
@ -220,6 +139,7 @@ subroutine ZMQ_pt2(pt2)
|
||||
tbc(i) = i
|
||||
computed(i) = .true.
|
||||
end do
|
||||
|
||||
pt2_detail = 0d0
|
||||
|
||||
time0 = omp_get_wtime()
|
||||
@ -237,14 +157,16 @@ subroutine ZMQ_pt2(pt2)
|
||||
|
||||
|
||||
call get_carlo_workbatch(1d-3, computed, comb, Ncomb, tbc)
|
||||
generator_per_task = tbc(0)/1000 + 1
|
||||
do i=1,tbc(0),generator_per_task
|
||||
generator_per_task = 1 ! tbc(0)/300 + 1
|
||||
print *, 'TASKS REVERSED'
|
||||
!do i=1,tbc(0),generator_per_task
|
||||
do i=tbc(0),1,-1 ! generator_per_task
|
||||
i_generator_end = min(i+generator_per_task-1, tbc(0))
|
||||
!print *, "TASK", (i_generator_end-i+1), tbc(i:i_generator_end)
|
||||
write(task,*) (i_generator_end-i+1), tbc(i:i_generator_end)
|
||||
call add_task_to_taskserver(zmq_to_qp_run_socket,task)
|
||||
end do
|
||||
|
||||
print *, "tasked"
|
||||
!$OMP PARALLEL DEFAULT(shared) SHARED(b, pt2) PRIVATE(i) NUM_THREADS(nproc+1)
|
||||
i = omp_get_thread_num()
|
||||
if (i==0) then
|
||||
@ -324,7 +246,7 @@ subroutine ZMQ_selection(N_in, pt2)
|
||||
|
||||
implicit none
|
||||
|
||||
character*(1000000) :: task
|
||||
character*(512) :: task
|
||||
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
|
||||
integer, intent(in) :: N_in
|
||||
type(selection_buffer) :: b
|
||||
@ -520,7 +442,7 @@ end function
|
||||
|
||||
BEGIN_PROVIDER [ integer, comb_teeth ]
|
||||
implicit none
|
||||
comb_teeth = 20
|
||||
comb_teeth = 100
|
||||
END_PROVIDER
|
||||
|
||||
|
||||
@ -565,7 +487,30 @@ subroutine get_carlo_workbatch(maxWorkload, computed, comb, Ncomb, tbc)
|
||||
comb(i) = comb(i) * comb_step
|
||||
call add_comb(comb(i), computed, tbc, myWorkload)
|
||||
Ncomb = i
|
||||
if(myWorkload > maxWorkload) exit
|
||||
if(myWorkload > maxWorkload .and. i >= 30) exit
|
||||
end do
|
||||
call reorder_tbc(tbc)
|
||||
end subroutine
|
||||
|
||||
|
||||
subroutine reorder_tbc(tbc)
|
||||
implicit none
|
||||
integer, intent(inout) :: tbc(0:N_det_generators)
|
||||
logical, allocatable :: ltbc(:)
|
||||
integer :: i, ci
|
||||
|
||||
allocate(ltbc(N_det_generators))
|
||||
ltbc = .false.
|
||||
do i=1,tbc(0)
|
||||
ltbc(tbc(i)) = .true.
|
||||
end do
|
||||
|
||||
ci = 0
|
||||
do i=1,N_det_generators
|
||||
if(ltbc(i)) then
|
||||
ci += 1
|
||||
tbc(ci) = i
|
||||
end if
|
||||
end do
|
||||
end subroutine
|
||||
|
||||
|
93
plugins/Full_CI_ZMQ/pt2_slave.irp.f
Normal file
93
plugins/Full_CI_ZMQ/pt2_slave.irp.f
Normal file
@ -0,0 +1,93 @@
|
||||
program pt2_slave
|
||||
implicit none
|
||||
BEGIN_DOC
|
||||
! Helper program to compute the PT2 in distributed mode.
|
||||
END_DOC
|
||||
|
||||
read_wf = .False.
|
||||
SOFT_TOUCH read_wf
|
||||
call provide_everything
|
||||
call switch_qp_run_to_master
|
||||
call run_wf
|
||||
end
|
||||
|
||||
subroutine provide_everything
|
||||
PROVIDE H_apply_buffer_allocated mo_bielec_integrals_in_map psi_det_generators psi_coef_generators psi_det_sorted_bit psi_selectors n_det_generators n_states generators_bitmask zmq_context
|
||||
! PROVIDE ci_electronic_energy mo_tot_num N_int
|
||||
end
|
||||
|
||||
subroutine run_wf
|
||||
use f77_zmq
|
||||
implicit none
|
||||
|
||||
integer(ZMQ_PTR), external :: new_zmq_to_qp_run_socket
|
||||
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
|
||||
double precision :: energy(N_states_diag)
|
||||
character*(64) :: states(1)
|
||||
integer :: rc, i
|
||||
|
||||
call provide_everything
|
||||
|
||||
zmq_context = f77_zmq_ctx_new ()
|
||||
states(1) = 'pt2'
|
||||
|
||||
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
|
||||
|
||||
do
|
||||
|
||||
call wait_for_states(states,zmq_state,1)
|
||||
|
||||
if(trim(zmq_state) == 'Stopped') then
|
||||
|
||||
exit
|
||||
|
||||
else if (trim(zmq_state) == 'pt2') then
|
||||
|
||||
! Selection
|
||||
! ---------
|
||||
|
||||
print *, 'PT2'
|
||||
call zmq_get_psi(zmq_to_qp_run_socket,1,energy,N_states_diag)
|
||||
|
||||
!$OMP PARALLEL PRIVATE(i)
|
||||
i = omp_get_thread_num()
|
||||
call pt2_slave_tcp(i, energy)
|
||||
!$OMP END PARALLEL
|
||||
print *, 'PT2 done'
|
||||
|
||||
endif
|
||||
|
||||
end do
|
||||
end
|
||||
|
||||
subroutine update_energy(energy)
|
||||
implicit none
|
||||
double precision, intent(in) :: energy(N_states_diag)
|
||||
BEGIN_DOC
|
||||
! Update energy when it is received from ZMQ
|
||||
END_DOC
|
||||
integer :: j,k
|
||||
do j=1,N_states
|
||||
do k=1,N_det
|
||||
CI_eigenvectors(k,j) = psi_coef(k,j)
|
||||
enddo
|
||||
enddo
|
||||
call u_0_S2_u_0(CI_eigenvectors_s2,CI_eigenvectors,N_det,psi_det,N_int)
|
||||
if (.True.) then
|
||||
do k=1,size(ci_electronic_energy)
|
||||
ci_electronic_energy(k) = energy(k)
|
||||
enddo
|
||||
TOUCH ci_electronic_energy CI_eigenvectors_s2 CI_eigenvectors
|
||||
endif
|
||||
|
||||
call write_double(6,ci_energy,'Energy')
|
||||
end
|
||||
|
||||
subroutine pt2_slave_tcp(i,energy)
|
||||
implicit none
|
||||
double precision, intent(in) :: energy(N_states_diag)
|
||||
integer, intent(in) :: i
|
||||
|
||||
call run_pt2_slave(0,i,energy)
|
||||
end
|
||||
|
Loading…
Reference in New Issue
Block a user