mirror of
https://github.com/LCPQ/quantum_package
synced 2025-01-05 11:00:10 +01:00
mrcc_zmq
This commit is contained in:
parent
2f2840ebb5
commit
d84fbabb8d
@ -393,6 +393,7 @@ subroutine mrcc_part_dress(delta_ij_, delta_ii_,delta_ij_s2_, delta_ii_s2_,i_gen
|
|||||||
k_sd = idx_alpha(l_sd)
|
k_sd = idx_alpha(l_sd)
|
||||||
call i_h_j(tq(1,1,i_alpha),psi_non_ref(1,1,idx_alpha(l_sd)),Nint,hij_cache(k_sd))
|
call i_h_j(tq(1,1,i_alpha),psi_non_ref(1,1,idx_alpha(l_sd)),Nint,hij_cache(k_sd))
|
||||||
call get_s2(tq(1,1,i_alpha),psi_non_ref(1,1,idx_alpha(l_sd)),Nint,sij_cache(k_sd))
|
call get_s2(tq(1,1,i_alpha),psi_non_ref(1,1,idx_alpha(l_sd)),Nint,sij_cache(k_sd))
|
||||||
|
!if(sij_cache(k_sd) /= 0D0) PRINT *, "SIJ ", sij_cache(k_sd)
|
||||||
enddo
|
enddo
|
||||||
|
|
||||||
! |I>
|
! |I>
|
||||||
@ -535,6 +536,56 @@ subroutine mrcc_part_dress(delta_ij_, delta_ii_,delta_ij_s2_, delta_ii_s2_,i_gen
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
BEGIN_PROVIDER [ double precision, mrcc_previous_E, (N_states) ]
|
||||||
|
implicit none
|
||||||
|
BEGIN_DOC
|
||||||
|
!energy difference between last two mrcc iterations
|
||||||
|
END_DOC
|
||||||
|
mrcc_previous_E(:) = ref_bitmask_energy
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
|
BEGIN_PROVIDER [ double precision, delta_ij_mrcc_zmq, (N_states,N_det_non_ref,N_det_ref) ]
|
||||||
|
&BEGIN_PROVIDER [ double precision, delta_ii_mrcc_zmq, (N_states, N_det_ref) ]
|
||||||
|
&BEGIN_PROVIDER [ double precision, delta_ij_s2_mrcc_zmq, (N_states,N_det_non_ref,N_det_ref) ]
|
||||||
|
&BEGIN_PROVIDER [ double precision, delta_ii_s2_mrcc_zmq, (N_states, N_det_ref) ]
|
||||||
|
use bitmasks
|
||||||
|
implicit none
|
||||||
|
|
||||||
|
integer :: i,j,k
|
||||||
|
|
||||||
|
double precision, allocatable :: mrcc(:)
|
||||||
|
double precision :: E_CI_before, relative_error
|
||||||
|
double precision, save :: errr = 0d0
|
||||||
|
|
||||||
|
allocate(mrcc(N_states))
|
||||||
|
|
||||||
|
|
||||||
|
delta_ij_mrcc_zmq = 0d0
|
||||||
|
delta_ii_mrcc_zmq = 0d0
|
||||||
|
delta_ij_s2_mrcc_zmq = 0d0
|
||||||
|
delta_ii_s2_mrcc_zmq = 0d0
|
||||||
|
|
||||||
|
!call random_seed()
|
||||||
|
E_CI_before = mrcc_E0_denominator(1) + nuclear_repulsion
|
||||||
|
threshold_selectors = 1.d0
|
||||||
|
threshold_generators = 1d0
|
||||||
|
!errr = errr / 2d0
|
||||||
|
if(errr /= 0d0) then
|
||||||
|
errr = errr / 4d0 ! (-mrcc_E0_denominator(1) + mrcc_previous_E(1)) / 1d1
|
||||||
|
else
|
||||||
|
errr = 4d-4
|
||||||
|
end if
|
||||||
|
relative_error = errr
|
||||||
|
print *, "RELATIVE ERROR", relative_error
|
||||||
|
call ZMQ_mrcc(E_CI_before, mrcc, delta_ij_mrcc_zmq, delta_ij_s2_mrcc_zmq, abs(relative_error))
|
||||||
|
!errr =
|
||||||
|
mrcc_previous_E(:) = mrcc_E0_denominator(:)
|
||||||
|
do i=N_det_non_ref,1,-1
|
||||||
|
delta_ii_mrcc_zmq(:,1) -= delta_ij_mrcc_zmq(:, i, 1) / psi_ref_coef(1,1) * psi_non_ref_coef(i, 1)
|
||||||
|
delta_ii_s2_mrcc_zmq(:,1) -= delta_ij_s2_mrcc_zmq(:, i, 1) / psi_ref_coef(1,1) * psi_non_ref_coef(i, 1)
|
||||||
|
end do
|
||||||
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
BEGIN_PROVIDER [ double precision, delta_ij, (N_states,N_det_non_ref,N_det_ref) ]
|
BEGIN_PROVIDER [ double precision, delta_ij, (N_states,N_det_non_ref,N_det_ref) ]
|
||||||
@ -559,6 +610,21 @@ end
|
|||||||
enddo
|
enddo
|
||||||
end do
|
end do
|
||||||
end do
|
end do
|
||||||
|
else if(mrmode == 5) then
|
||||||
|
do i = 1, N_det_ref
|
||||||
|
do i_state = 1, N_states
|
||||||
|
delta_ii(i_state,i)= delta_ii_mrcc_zmq(i_state,i)
|
||||||
|
delta_ii_s2(i_state,i)= delta_ii_s2_mrcc_zmq(i_state,i)
|
||||||
|
enddo
|
||||||
|
do j = 1, N_det_non_ref
|
||||||
|
do i_state = 1, N_states
|
||||||
|
delta_ij(i_state,j,i) = delta_ij_mrcc_zmq(i_state,j,i)
|
||||||
|
delta_ij_s2(i_state,j,i) = delta_ij_s2_mrcc_zmq(i_state,j,i)
|
||||||
|
enddo
|
||||||
|
end do
|
||||||
|
end do
|
||||||
|
print *, "De", delta_ij(1,:5,1)
|
||||||
|
print *, "Ds", delta_ij_s2(1,1000:1005,1)
|
||||||
else if(mrmode == 3) then
|
else if(mrmode == 3) then
|
||||||
do i = 1, N_det_ref
|
do i = 1, N_det_ref
|
||||||
do i_state = 1, N_states
|
do i_state = 1, N_states
|
||||||
|
@ -3,7 +3,7 @@ program mrcc_slave
|
|||||||
BEGIN_DOC
|
BEGIN_DOC
|
||||||
! Helper program to compute the mrcc in distributed mode.
|
! Helper program to compute the mrcc in distributed mode.
|
||||||
END_DOC
|
END_DOC
|
||||||
|
print *, "SLAVE"
|
||||||
read_wf = .False.
|
read_wf = .False.
|
||||||
distributed_davidson = .False.
|
distributed_davidson = .False.
|
||||||
SOFT_TOUCH read_wf distributed_davidson
|
SOFT_TOUCH read_wf distributed_davidson
|
||||||
|
@ -20,11 +20,11 @@ subroutine run
|
|||||||
|
|
||||||
allocate (mrcc(N_states))
|
allocate (mrcc(N_states))
|
||||||
mrcc = 0.d0
|
mrcc = 0.d0
|
||||||
|
!call random_seed()
|
||||||
E_CI_before = mrcc_E0_denominator(1) + nuclear_repulsion
|
E_CI_before = mrcc_E0_denominator(1) + nuclear_repulsion
|
||||||
threshold_selectors = 1.d0
|
threshold_selectors = 1.d0
|
||||||
threshold_generators = 1d0
|
threshold_generators = 1d0
|
||||||
relative_error = 1.d-3
|
relative_error = 5.d-2
|
||||||
call ZMQ_mrcc(E_CI_before, mrcc, relative_error)
|
call ZMQ_mrcc(E_CI_before, mrcc, relative_error)
|
||||||
!print *, 'Final step'
|
!print *, 'Final step'
|
||||||
!print *, 'N_det = ', N_det
|
!print *, 'N_det = ', N_det
|
||||||
|
@ -3,18 +3,20 @@ BEGIN_PROVIDER [ integer, fragment_first ]
|
|||||||
fragment_first = first_det_of_teeth(1)
|
fragment_first = first_det_of_teeth(1)
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
subroutine ZMQ_mrcc(E, mrcc,relative_error)
|
subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, relative_error)
|
||||||
|
use dress_types
|
||||||
use f77_zmq
|
use f77_zmq
|
||||||
use selection_types
|
|
||||||
|
|
||||||
implicit none
|
implicit none
|
||||||
|
|
||||||
character(len=64000) :: task
|
character(len=64000) :: task
|
||||||
integer(ZMQ_PTR) :: zmq_to_qp_run_socket, zmq_to_qp_run_socket2
|
integer(ZMQ_PTR) :: zmq_to_qp_run_socket, zmq_to_qp_run_socket2
|
||||||
type(selection_buffer) :: b
|
|
||||||
integer, external :: omp_get_thread_num
|
integer, external :: omp_get_thread_num
|
||||||
double precision, intent(in) :: relative_error, E
|
double precision, intent(in) :: relative_error, E
|
||||||
double precision, intent(out) :: mrcc(N_states)
|
double precision, intent(out) :: mrcc(N_states)
|
||||||
|
double precision, intent(out) :: delta(N_states, N_det_non_ref)
|
||||||
|
double precision, intent(out) :: delta_s2(N_states, N_det_non_ref)
|
||||||
|
type(dress_buffer) :: db(2)
|
||||||
|
|
||||||
|
|
||||||
double precision, allocatable :: mrcc_detail(:,:), comb(:)
|
double precision, allocatable :: mrcc_detail(:,:), comb(:)
|
||||||
@ -32,6 +34,10 @@ subroutine ZMQ_mrcc(E, mrcc,relative_error)
|
|||||||
! return
|
! return
|
||||||
!else
|
!else
|
||||||
|
|
||||||
|
|
||||||
|
call init_dress_buffer(db(1))
|
||||||
|
call init_dress_buffer(db(2))
|
||||||
|
|
||||||
allocate(mrcc_detail(N_states, N_det_generators+1), comb(N_det_generators), computed(N_det_generators), tbc(0:size_tbc))
|
allocate(mrcc_detail(N_states, N_det_generators+1), comb(N_det_generators), computed(N_det_generators), tbc(0:size_tbc))
|
||||||
sumabove = 0d0
|
sumabove = 0d0
|
||||||
sum2above = 0d0
|
sum2above = 0d0
|
||||||
@ -55,7 +61,6 @@ subroutine ZMQ_mrcc(E, mrcc,relative_error)
|
|||||||
|
|
||||||
call new_parallel_job(zmq_to_qp_run_socket,'mrcc')
|
call new_parallel_job(zmq_to_qp_run_socket,'mrcc')
|
||||||
call zmq_put_psi(zmq_to_qp_run_socket,1,mrcc_e0_denominator,size(mrcc_e0_denominator))
|
call zmq_put_psi(zmq_to_qp_run_socket,1,mrcc_e0_denominator,size(mrcc_e0_denominator))
|
||||||
call create_selection_buffer(1, 1*2, b)
|
|
||||||
|
|
||||||
Ncomb=size(comb)
|
Ncomb=size(comb)
|
||||||
call get_carlo_workbatch(computed, comb, Ncomb, tbc)
|
call get_carlo_workbatch(computed, comb, Ncomb, tbc)
|
||||||
@ -68,7 +73,6 @@ subroutine ZMQ_mrcc(E, mrcc,relative_error)
|
|||||||
integer(ZMQ_PTR), external :: new_zmq_to_qp_run_socket
|
integer(ZMQ_PTR), external :: new_zmq_to_qp_run_socket
|
||||||
integer :: ipos
|
integer :: ipos
|
||||||
ipos=1
|
ipos=1
|
||||||
|
|
||||||
do i=1,tbc(0)
|
do i=1,tbc(0)
|
||||||
if(tbc(i) > fragment_first) then
|
if(tbc(i) > fragment_first) then
|
||||||
write(task(ipos:ipos+20),'(I9,1X,I9,''|'')') 0, tbc(i)
|
write(task(ipos:ipos+20),'(I9,1X,I9,''|'')') 0, tbc(i)
|
||||||
@ -98,28 +102,36 @@ subroutine ZMQ_mrcc(E, mrcc,relative_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 mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabove, sum2above, Nabove, relative_error, mrcc)
|
call mrcc_collector(E, db, tbc, comb, Ncomb, computed, mrcc_detail, sumabove, sum2above, Nabove, relative_error, mrcc)
|
||||||
else
|
else
|
||||||
call mrcc_slave_inproc(i)
|
call mrcc_slave_inproc(i)
|
||||||
endif
|
endif
|
||||||
!$OMP END PARALLEL
|
!$OMP END PARALLEL
|
||||||
call delete_selection_buffer(b)
|
|
||||||
call end_parallel_job(zmq_to_qp_run_socket, 'mrcc')
|
call end_parallel_job(zmq_to_qp_run_socket, 'mrcc')
|
||||||
|
|
||||||
print *, '========== ================= ================= ================='
|
print *, '========== ================= ================= ================='
|
||||||
|
|
||||||
!endif
|
!endif
|
||||||
|
call flush_dress_buffer(db(1), delta)
|
||||||
|
call flush_dress_buffer(db(2), delta_s2)
|
||||||
|
deallocate(db(1)%buf)
|
||||||
|
deallocate(db(2)%buf)
|
||||||
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
|
||||||
subroutine do_carlo(tbc, Ncomb, comb, mrcc_detail, computed, sumabove, sum2above, Nabove)
|
subroutine do_carlo(tbc, Ncomb, comb, mrcc_detail, db, computed, sumabove, sum2above, sumin, isincomb, Nabove)
|
||||||
|
use dress_types
|
||||||
|
implicit none
|
||||||
|
|
||||||
integer, intent(in) :: tbc(0:size_tbc), Ncomb
|
integer, intent(in) :: tbc(0:size_tbc), Ncomb
|
||||||
logical, intent(in) :: computed(N_det_generators)
|
logical, intent(in) :: computed(N_det_generators)
|
||||||
double precision, intent(in) :: comb(Ncomb), mrcc_detail(N_states, N_det_generators)
|
double precision, intent(in) :: comb(Ncomb), mrcc_detail(N_states, N_det_generators)
|
||||||
double precision, intent(inout) :: sumabove(comb_teeth), sum2above(comb_teeth), Nabove(comb_teeth)
|
double precision, intent(inout) :: sumabove(comb_teeth), sum2above(comb_teeth), sumin(comb_teeth), Nabove(comb_teeth)
|
||||||
integer :: i, dets(comb_teeth)
|
double precision, intent(inout) :: isincomb(N_det_generators)
|
||||||
double precision :: myVal, myVal2
|
type(dress_buffer), intent(inout) :: db(2)
|
||||||
|
integer :: i, j, dets(comb_teeth)
|
||||||
|
double precision :: myVal, myVal2, myValcur
|
||||||
|
|
||||||
mainLoop : do i=1,Ncomb
|
mainLoop : do i=1,Ncomb
|
||||||
call get_comb(comb(i), dets, comb_teeth)
|
call get_comb(comb(i), dets, comb_teeth)
|
||||||
@ -132,11 +144,18 @@ subroutine do_carlo(tbc, Ncomb, comb, mrcc_detail, computed, sumabove, sum2above
|
|||||||
myVal = 0d0
|
myVal = 0d0
|
||||||
myVal2 = 0d0
|
myVal2 = 0d0
|
||||||
do j=comb_teeth,1,-1
|
do j=comb_teeth,1,-1
|
||||||
myVal += mrcc_detail(1, dets(j)) * mrcc_weight_inv(dets(j)) * comb_step
|
isincomb(dets(j)) = 1d0
|
||||||
|
myValcur = mrcc_detail(1, dets(j)) * mrcc_weight_inv(dets(j)) * comb_step
|
||||||
|
sumin(j) += myValcur**2
|
||||||
|
myVal += myValcur
|
||||||
sumabove(j) += myVal
|
sumabove(j) += myVal
|
||||||
|
call dress_buffer_drew(db(1), dets(j), mrcc_weight_inv(dets(j)) * comb_step)
|
||||||
|
call dress_buffer_drew(db(2), dets(j), mrcc_weight_inv(dets(j)) * comb_step)
|
||||||
sum2above(j) += myVal*myVal
|
sum2above(j) += myVal*myVal
|
||||||
Nabove(j) += 1
|
Nabove(j) += 1
|
||||||
end do
|
end do
|
||||||
|
db(1)%N += 1d0
|
||||||
|
db(2)%N += 1d0
|
||||||
end do mainLoop
|
end do mainLoop
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
@ -148,15 +167,17 @@ subroutine mrcc_slave_inproc(i)
|
|||||||
call run_mrcc_slave(1,i,mrcc_e0_denominator)
|
call run_mrcc_slave(1,i,mrcc_e0_denominator)
|
||||||
end
|
end
|
||||||
|
|
||||||
subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabove, sum2above, Nabove, relative_error, mrcc)
|
|
||||||
|
subroutine mrcc_collector(E, db, tbc, comb, Ncomb, computed, mrcc_detail, sumabove, sum2above, Nabove, relative_error, mrcc)
|
||||||
|
use dress_types
|
||||||
use f77_zmq
|
use f77_zmq
|
||||||
use selection_types
|
|
||||||
use bitmasks
|
use bitmasks
|
||||||
implicit none
|
implicit none
|
||||||
|
|
||||||
|
|
||||||
integer, intent(in) :: Ncomb
|
integer, intent(in) :: Ncomb
|
||||||
double precision, intent(inout) :: mrcc_detail(N_states, N_det_generators)
|
double precision, intent(inout) :: mrcc_detail(N_states, N_det_generators)
|
||||||
|
type(dress_buffer), intent(inout) :: db(2)
|
||||||
double precision, intent(in) :: comb(Ncomb), relative_error, E
|
double precision, intent(in) :: comb(Ncomb), relative_error, E
|
||||||
logical, intent(inout) :: computed(N_det_generators)
|
logical, intent(inout) :: computed(N_det_generators)
|
||||||
integer, intent(in) :: tbc(0:size_tbc)
|
integer, intent(in) :: tbc(0:size_tbc)
|
||||||
@ -164,7 +185,6 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
double precision, intent(out) :: mrcc(N_states)
|
double precision, intent(out) :: mrcc(N_states)
|
||||||
|
|
||||||
|
|
||||||
type(selection_buffer), intent(inout) :: b
|
|
||||||
double precision, allocatable :: mrcc_mwen(:,:)
|
double precision, allocatable :: mrcc_mwen(:,:)
|
||||||
integer(ZMQ_PTR),external :: new_zmq_to_qp_run_socket
|
integer(ZMQ_PTR),external :: new_zmq_to_qp_run_socket
|
||||||
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
|
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
|
||||||
@ -174,20 +194,28 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
|
|
||||||
integer :: msg_size, rc, more
|
integer :: msg_size, rc, more
|
||||||
integer :: acc, i, j, robin, N, ntask
|
integer :: acc, i, j, robin, N, ntask
|
||||||
double precision, allocatable :: val(:)
|
|
||||||
integer(bit_kind), allocatable :: det(:,:,:)
|
integer(bit_kind), allocatable :: det(:,:,:)
|
||||||
integer, allocatable :: task_id(:)
|
integer, allocatable :: task_id(:)
|
||||||
integer :: Nindex
|
integer :: Nindex
|
||||||
integer, allocatable :: index(:)
|
integer, allocatable :: ind(:)
|
||||||
double precision, save :: time0 = -1.d0
|
double precision, save :: time0 = -1.d0
|
||||||
double precision :: time, timeLast, Nabove_old
|
double precision :: time, timeLast, Nabove_old
|
||||||
double precision, external :: omp_get_wtime
|
double precision, external :: omp_get_wtime
|
||||||
integer :: tooth, firstTBDcomb, orgTBDcomb
|
integer :: tooth, firstTBDcomb, orgTBDcomb
|
||||||
integer, allocatable :: parts_to_get(:)
|
integer, allocatable :: parts_to_get(:)
|
||||||
logical, allocatable :: actually_computed(:)
|
logical, allocatable :: actually_computed(:)
|
||||||
integer :: ncomputed
|
double precision :: ncomputed
|
||||||
|
integer :: total_computed
|
||||||
|
|
||||||
ncomputed = 0
|
double precision :: sumin(comb_teeth)
|
||||||
|
double precision :: isincomb(N_det_generators)
|
||||||
|
|
||||||
|
print *, "collecture"
|
||||||
|
|
||||||
|
ncomputed = 0d0
|
||||||
|
total_computed = 0
|
||||||
|
sumin = 0d0
|
||||||
|
isincomb = 0d0
|
||||||
|
|
||||||
character*(512) :: task
|
character*(512) :: task
|
||||||
Nabove_old = -1.d0
|
Nabove_old = -1.d0
|
||||||
@ -195,6 +223,8 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
allocate(actually_computed(N_det_generators), parts_to_get(N_det_generators), &
|
allocate(actually_computed(N_det_generators), parts_to_get(N_det_generators), &
|
||||||
mrcc_mwen(N_states, N_det_generators) )
|
mrcc_mwen(N_states, N_det_generators) )
|
||||||
mrcc_mwen(1:N_states, 1:N_det_generators) =0.d0
|
mrcc_mwen(1:N_states, 1:N_det_generators) =0.d0
|
||||||
|
|
||||||
|
|
||||||
do i=1,N_det_generators
|
do i=1,N_det_generators
|
||||||
actually_computed(i) = computed(i)
|
actually_computed(i) = computed(i)
|
||||||
enddo
|
enddo
|
||||||
@ -215,7 +245,7 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
|
|
||||||
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
|
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
|
||||||
zmq_socket_pull = new_zmq_pull_socket()
|
zmq_socket_pull = new_zmq_pull_socket()
|
||||||
allocate(val(b%N), det(N_int, 2, b%N), task_id(N_det_generators), index(1))
|
allocate(task_id(N_det_generators), ind(db(1)%N_slot))
|
||||||
more = 1
|
more = 1
|
||||||
if (time0 < 0.d0) then
|
if (time0 < 0.d0) then
|
||||||
call wall_time(time0)
|
call wall_time(time0)
|
||||||
@ -224,22 +254,26 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
|
|
||||||
call get_first_tooth(actually_computed, tooth)
|
call get_first_tooth(actually_computed, tooth)
|
||||||
Nabove_old = Nabove(tooth)
|
Nabove_old = Nabove(tooth)
|
||||||
|
db(1)%free_under = first_det_of_teeth(1)-1
|
||||||
|
db(2)%free_under = first_det_of_teeth(1)-1
|
||||||
|
|
||||||
pullLoop : do while (more == 1)
|
pullLoop : do while (more == 1)
|
||||||
|
|
||||||
call pull_mrcc_results(zmq_socket_pull, Nindex, index, mrcc_mwen, task_id, ntask)
|
call pull_mrcc_results(zmq_socket_pull, Nindex, ind, mrcc_mwen, db, task_id, ntask)
|
||||||
do i=1,Nindex
|
do i=1,Nindex
|
||||||
mrcc_detail(1:N_states, index(i)) += mrcc_mwen(1:N_states,i)
|
mrcc_detail(1:N_states, ind(i)) += mrcc_mwen(1:N_states,i)
|
||||||
parts_to_get(index(i)) -= 1
|
|
||||||
if(parts_to_get(index(i)) < 0) then
|
parts_to_get(ind(i)) -= 1
|
||||||
print *, i, index(i), parts_to_get(index(i)), Nindex
|
if(parts_to_get(ind(i)) < 0) then
|
||||||
|
print *, i, ind(i), parts_to_get(ind(i)), Nindex
|
||||||
print *, "PARTS ??"
|
print *, "PARTS ??"
|
||||||
print *, parts_to_get
|
print *, parts_to_get
|
||||||
stop "PARTS ??"
|
stop "PARTS ??"
|
||||||
end if
|
end if
|
||||||
if(parts_to_get(index(i)) == 0) then
|
if(parts_to_get(ind(i)) == 0) then
|
||||||
actually_computed(index(i)) = .true.
|
!print *, "COMPUTED", ind(i)
|
||||||
ncomputed += 1
|
actually_computed(ind(i)) = .true.
|
||||||
|
total_computed += 1
|
||||||
end if
|
end if
|
||||||
end do
|
end do
|
||||||
|
|
||||||
@ -250,6 +284,10 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
call zmq_delete_task(zmq_to_qp_run_socket,zmq_socket_pull,task_id(i),more)
|
call zmq_delete_task(zmq_to_qp_run_socket,zmq_socket_pull,task_id(i),more)
|
||||||
end do
|
end do
|
||||||
|
|
||||||
|
call get_first_tooth(actually_computed, tooth)
|
||||||
|
db(1)%free_under = first_det_of_teeth(tooth)-1
|
||||||
|
db(2)%free_under = first_det_of_teeth(tooth)-1
|
||||||
|
|
||||||
time = omp_get_wtime()
|
time = omp_get_wtime()
|
||||||
|
|
||||||
if(time - timeLast > 1d0 .or. more /= 1) then
|
if(time - timeLast > 1d0 .or. more /= 1) then
|
||||||
@ -260,12 +298,12 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
end if
|
end if
|
||||||
end do
|
end do
|
||||||
|
|
||||||
double precision :: E0, avg, eqt, prop
|
double precision :: E0, fco, ffco, avg, tavg, mavg, var, su, su2, meqt, eqt, prop
|
||||||
call do_carlo(tbc, Ncomb+1-firstTBDcomb, comb(firstTBDcomb), mrcc_detail, actually_computed, sumabove, sum2above, Nabove)
|
if(firstTBDcomb <= size(comb)) then
|
||||||
|
call do_carlo(tbc, Ncomb+1-firstTBDcomb, comb(firstTBDcomb), mrcc_detail, db, actually_computed, sumabove, sum2above, sumin, isincomb, Nabove)
|
||||||
firstTBDcomb = int(Nabove(1)) - orgTBDcomb + 1
|
firstTBDcomb = int(Nabove(1)) - orgTBDcomb + 1
|
||||||
|
end if
|
||||||
if(Nabove(1) < 5d0) cycle
|
if(Nabove(1) < 5d0) cycle
|
||||||
call get_first_tooth(actually_computed, tooth)
|
|
||||||
|
|
||||||
E0 = sum(mrcc_detail(1,:first_det_of_teeth(tooth)-1))
|
E0 = sum(mrcc_detail(1,:first_det_of_teeth(tooth)-1))
|
||||||
if (tooth <= comb_teeth) then
|
if (tooth <= comb_teeth) then
|
||||||
prop = ((1d0 - dfloat(comb_teeth - tooth + 1) * comb_step) - mrcc_cweight(first_det_of_teeth(tooth)-1))
|
prop = ((1d0 - dfloat(comb_teeth - tooth + 1) * comb_step) - mrcc_cweight(first_det_of_teeth(tooth)-1))
|
||||||
@ -277,17 +315,82 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
eqt = 0.d0
|
eqt = 0.d0
|
||||||
endif
|
endif
|
||||||
call wall_time(time)
|
call wall_time(time)
|
||||||
if (dabs(eqt/avg) < relative_error) then
|
!if (dabs(eqt/avg) < relative_error) then
|
||||||
|
if (dabs(eqt) < relative_error .or. total_computed == N_det_generators) then
|
||||||
! Termination
|
! Termination
|
||||||
mrcc(1) = avg
|
print *, "converged", Nabove(1), first_det_of_teeth(tooth)
|
||||||
print '(G10.3, 2X, F16.7, 2X, G16.3, 2X, F16.4, A20)', Nabove(tooth), avg+E, eqt, time-time0, ''
|
!mrcc(1) = avg+E
|
||||||
print *, avg
|
print '(A7, G10.3, 2X, F16.7, 2X, G16.3, 2X, F16.4, A20)', "GREPME", Nabove(tooth), E+avg, eqt, time-time0, ''
|
||||||
call zmq_abort(zmq_to_qp_run_socket)
|
call zmq_abort(zmq_to_qp_run_socket)
|
||||||
else
|
else
|
||||||
if (Nabove(tooth) > Nabove_old) then
|
if (Nabove(tooth) > Nabove_old) then
|
||||||
print '(G10.3, 2X, F16.7, 2X, G16.3, 2X, F16.4, A20)', Nabove(tooth), avg+E, eqt, time-time0, ''
|
meqt = 0d0
|
||||||
print *, avg
|
ncomputed = 0
|
||||||
|
mavg = 0d0
|
||||||
|
do i=tooth, comb_teeth
|
||||||
|
!do j=first_det_of_teeth(i), first_det_of_teeth(i+1)-1
|
||||||
|
! if(actually_computed(j)) ncomputed(i) = ncomputed(i) + 1
|
||||||
|
!end do
|
||||||
|
fco = 0d0
|
||||||
|
ffco = 0d0
|
||||||
|
do j=first_det_of_teeth(i), first_det_of_teeth(i+1)-1
|
||||||
|
fco += isincomb(j) * mrcc_weight(j)
|
||||||
|
ffco += mrcc_weight(j)
|
||||||
|
end do
|
||||||
|
ncomputed = sum(isincomb(first_det_of_teeth(i):first_det_of_teeth(i+1)-1))
|
||||||
|
|
||||||
|
!if(i /= comb_teeth) then
|
||||||
|
! var = abs((sumin(i))/Nabove(i) - ((sumabove(i)-sumabove(i+1))/Nabove(i))**2) / (Nabove(i)-1)
|
||||||
|
!else
|
||||||
|
! var = abs((sumin(i))/Nabove(i) - ((sumabove(i))/Nabove(i))**2) / (Nabove(i)-1)
|
||||||
|
!end if
|
||||||
|
n = first_det_of_teeth(i+1) - first_det_of_teeth(i)
|
||||||
|
|
||||||
|
|
||||||
|
!var = var * ((ffco-fco) /ffco) !((dfloat(n)-ncomputed) / dfloat(n))**2
|
||||||
|
!eqt += var / (Nabove(i)-1)
|
||||||
|
|
||||||
|
tavg = 0d0
|
||||||
|
ncomputed = 0d0
|
||||||
|
su = 0d0
|
||||||
|
su2 = 0d0
|
||||||
|
do j=first_det_of_teeth(i), first_det_of_teeth(i+1)-1
|
||||||
|
if(actually_computed(j)) then
|
||||||
|
tavg += (mrcc_detail(1, j))! * isincomb(j)
|
||||||
|
ncomputed += 1d0 !isincomb(j)
|
||||||
|
su2 += (mrcc_detail(1, j))**2
|
||||||
|
end if
|
||||||
|
end do
|
||||||
|
if(ncomputed /= 0) then
|
||||||
|
tavg = tavg / ncomputed * dfloat(n)
|
||||||
|
su2 = su2 / ncomputed * dfloat(n)
|
||||||
|
var = (su2 - (tavg**2)) / ncomputed
|
||||||
|
else
|
||||||
|
print *, "ZERO NCOMPUTED"
|
||||||
|
tavg = 0d0
|
||||||
|
su2 = 0d0
|
||||||
|
var = 0d0
|
||||||
|
end if
|
||||||
|
|
||||||
|
!fco = ffco
|
||||||
|
!if(i /= comb_teeth) then
|
||||||
|
! mavg += (tavg) + (((sumabove(i)-sumabove(i+1))/Nabove(i)) * (ffco-fco)) &
|
||||||
|
! / ffco
|
||||||
|
!else
|
||||||
|
! mavg += (tavg) + (((sumabove(i))/Nabove(i)) * (ffco-fco)) &
|
||||||
|
! / ffco
|
||||||
|
!end if
|
||||||
|
|
||||||
|
|
||||||
|
var = var * ((dfloat(n)-ncomputed) / dfloat(n))
|
||||||
|
meqt += var
|
||||||
|
mavg += tavg
|
||||||
|
end do
|
||||||
|
meqt = sqrt(abs(meqt))
|
||||||
Nabove_old = Nabove(tooth)
|
Nabove_old = Nabove(tooth)
|
||||||
|
|
||||||
|
print '(G10.3, 2X, F16.7, 2X, G16.3, 2X, F16.4, A20)', Nabove(tooth), avg+E, eqt, time-time0, ''
|
||||||
|
!print *, "GREPME", avg, eqt, mavg+E0, meqt
|
||||||
endif
|
endif
|
||||||
endif
|
endif
|
||||||
end if
|
end if
|
||||||
@ -297,11 +400,10 @@ subroutine mrcc_collector(E, b, tbc, comb, Ncomb, computed, mrcc_detail, sumabov
|
|||||||
prop = ((1d0 - dfloat(comb_teeth - tooth + 1) * comb_step) - mrcc_cweight(first_det_of_teeth(tooth)-1))
|
prop = ((1d0 - dfloat(comb_teeth - tooth + 1) * comb_step) - mrcc_cweight(first_det_of_teeth(tooth)-1))
|
||||||
prop = prop * mrcc_weight_inv(first_det_of_teeth(tooth))
|
prop = prop * mrcc_weight_inv(first_det_of_teeth(tooth))
|
||||||
E0 += mrcc_detail(1,first_det_of_teeth(tooth)) * prop
|
E0 += mrcc_detail(1,first_det_of_teeth(tooth)) * prop
|
||||||
mrcc(1) = E0 + (sumabove(tooth) / Nabove(tooth))
|
mrcc(1) = E + E0 + (sumabove(tooth) / Nabove(tooth))
|
||||||
|
|
||||||
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
|
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
|
||||||
call end_zmq_pull_socket(zmq_socket_pull)
|
call end_zmq_pull_socket(zmq_socket_pull)
|
||||||
call sort_selection_buffer(b)
|
|
||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
integer function mrcc_find(v, w, sze, imin, imax)
|
integer function mrcc_find(v, w, sze, imin, imax)
|
||||||
@ -333,7 +435,7 @@ end function
|
|||||||
|
|
||||||
BEGIN_PROVIDER [ integer, comb_teeth ]
|
BEGIN_PROVIDER [ integer, comb_teeth ]
|
||||||
implicit none
|
implicit none
|
||||||
comb_teeth = 100
|
comb_teeth = 10
|
||||||
END_PROVIDER
|
END_PROVIDER
|
||||||
|
|
||||||
|
|
||||||
@ -483,7 +585,7 @@ end subroutine
|
|||||||
comb_step = 1d0/dfloat(comb_teeth)
|
comb_step = 1d0/dfloat(comb_teeth)
|
||||||
first_det_of_comb = 1
|
first_det_of_comb = 1
|
||||||
do i=1,N_det_generators
|
do i=1,N_det_generators
|
||||||
if(mrcc_weight(i)/norm_left < .5d0*comb_step) then
|
if(mrcc_weight(i)/norm_left < .25d0*comb_step) then
|
||||||
first_det_of_comb = i
|
first_det_of_comb = i
|
||||||
exit
|
exit
|
||||||
end if
|
end if
|
||||||
@ -492,6 +594,7 @@ end subroutine
|
|||||||
first_det_of_comb = max(2,first_det_of_comb)
|
first_det_of_comb = max(2,first_det_of_comb)
|
||||||
call write_int(6, first_det_of_comb-1, 'Size of deterministic set')
|
call write_int(6, first_det_of_comb-1, 'Size of deterministic set')
|
||||||
|
|
||||||
|
|
||||||
comb_step = (1d0 - mrcc_cweight(first_det_of_comb-1)) * comb_step
|
comb_step = (1d0 - mrcc_cweight(first_det_of_comb-1)) * comb_step
|
||||||
|
|
||||||
stato = 1d0 - comb_step
|
stato = 1d0 - comb_step
|
||||||
@ -504,6 +607,30 @@ end subroutine
|
|||||||
end do
|
end do
|
||||||
first_det_of_teeth(comb_teeth+1) = N_det_generators + 1
|
first_det_of_teeth(comb_teeth+1) = N_det_generators + 1
|
||||||
first_det_of_teeth(1) = first_det_of_comb
|
first_det_of_teeth(1) = first_det_of_comb
|
||||||
|
|
||||||
|
!do i=1,comb_teeth
|
||||||
|
! mrcc_weight(first_det_of_teeth(i):first_det_of_teeth(i+1)-1) = &
|
||||||
|
! (mrcc_cweight(first_det_of_teeth(i+1)-1)-mrcc_cweight(first_det_of_teeth(i)-1)) / &
|
||||||
|
! dfloat(first_det_of_teeth(i+1)-first_det_of_teeth(i))
|
||||||
|
!end do
|
||||||
|
|
||||||
|
!mrcc_cweight = 0d0
|
||||||
|
!mrcc_cweight(N_det_generators) = mrcc_weight(N_det_generators)
|
||||||
|
!do i=N_det_generators-1,1,-1
|
||||||
|
! mrcc_cweight(i) = mrcc_weight(i) + mrcc_cweight(i+1)
|
||||||
|
!end do
|
||||||
|
|
||||||
|
!do i=1,N_det_generators
|
||||||
|
! mrcc_weight(i) = mrcc_weight(i) / mrcc_cweight(1)
|
||||||
|
! mrcc_cweight(i) = mrcc_cweight(i) / mrcc_cweight(1)
|
||||||
|
! enddo
|
||||||
|
|
||||||
|
!do i=1,N_det_generators-1
|
||||||
|
! mrcc_cweight(i) = 1.d0 - mrcc_cweight(i+1)
|
||||||
|
!end do
|
||||||
|
!mrcc_cweight(N_det_generators) = 1.d0
|
||||||
|
|
||||||
|
|
||||||
if(first_det_of_teeth(1) /= first_det_of_comb) then
|
if(first_det_of_teeth(1) /= first_det_of_comb) then
|
||||||
print *, 'Error in ', irp_here
|
print *, 'Error in ', irp_here
|
||||||
stop "comb provider"
|
stop "comb provider"
|
||||||
|
@ -41,12 +41,12 @@ subroutine run(N_st,energy)
|
|||||||
print *, 'Iteration', iteration, '/', n_it_mrcc_max
|
print *, 'Iteration', iteration, '/', n_it_mrcc_max
|
||||||
print *, '==============================================='
|
print *, '==============================================='
|
||||||
print *, ''
|
print *, ''
|
||||||
E_old = sum(ci_energy_dressed(1:N_states))
|
E_old = mrcc_e0_denominator(1) !sum(ci_energy_dressed(1:N_states))
|
||||||
do i=1,N_st
|
do i=1,N_st
|
||||||
call write_double(6,ci_energy_dressed(i),"Energy")
|
call write_double(6,ci_energy_dressed(i),"Energy")
|
||||||
enddo
|
enddo
|
||||||
call diagonalize_ci_dressed(lambda)
|
call diagonalize_ci_dressed(lambda)
|
||||||
E_new = sum(ci_energy_dressed(1:N_states))
|
E_new = mrcc_e0_denominator(1) !sum(ci_energy_dressed(1:N_states))
|
||||||
! if (.true.) then
|
! if (.true.) then
|
||||||
! provide delta_ij_mrcc_pouet
|
! provide delta_ij_mrcc_pouet
|
||||||
! endif
|
! endif
|
||||||
|
@ -9,8 +9,8 @@ END_PROVIDER
|
|||||||
|
|
||||||
|
|
||||||
subroutine run_mrcc_slave(thread,iproc,energy)
|
subroutine run_mrcc_slave(thread,iproc,energy)
|
||||||
|
use dress_types
|
||||||
use f77_zmq
|
use f77_zmq
|
||||||
use selection_types
|
|
||||||
implicit none
|
implicit none
|
||||||
|
|
||||||
double precision, intent(in) :: energy(N_states_diag)
|
double precision, intent(in) :: energy(N_states_diag)
|
||||||
@ -26,11 +26,10 @@ subroutine run_mrcc_slave(thread,iproc,energy)
|
|||||||
integer(ZMQ_PTR), external :: new_zmq_push_socket
|
integer(ZMQ_PTR), external :: new_zmq_push_socket
|
||||||
integer(ZMQ_PTR) :: zmq_socket_push
|
integer(ZMQ_PTR) :: zmq_socket_push
|
||||||
|
|
||||||
!type(selection_buffer) :: buf
|
|
||||||
logical :: done
|
logical :: done
|
||||||
|
|
||||||
double precision,allocatable :: mrcc_detail(:,:)
|
double precision,allocatable :: mrcc_detail(:,:)
|
||||||
integer :: index
|
integer :: ind(1)
|
||||||
integer :: Nindex
|
integer :: Nindex
|
||||||
|
|
||||||
integer(bit_kind),allocatable :: abuf(:,:,:)
|
integer(bit_kind),allocatable :: abuf(:,:,:)
|
||||||
@ -74,7 +73,7 @@ subroutine run_mrcc_slave(thread,iproc,energy)
|
|||||||
ctask = ctask - 1
|
ctask = ctask - 1
|
||||||
else
|
else
|
||||||
integer :: i_generator, i_i_generator, subset
|
integer :: i_generator, i_i_generator, subset
|
||||||
read (task,*) subset, index
|
read (task,*) subset, ind
|
||||||
|
|
||||||
! if(buf%N == 0) then
|
! if(buf%N == 0) then
|
||||||
! ! Only first time
|
! ! Only first time
|
||||||
@ -82,7 +81,11 @@ subroutine run_mrcc_slave(thread,iproc,energy)
|
|||||||
! end if
|
! end if
|
||||||
do i_i_generator=1, Nindex
|
do i_i_generator=1, Nindex
|
||||||
contrib = 0d0
|
contrib = 0d0
|
||||||
i_generator = index
|
i_generator = ind(i_i_generator)
|
||||||
|
delta_ij_loc = 0d0
|
||||||
|
delta_ii_loc = 0d0
|
||||||
|
delta_ij_s2_loc = 0d0
|
||||||
|
delta_ii_s2_loc = 0d0
|
||||||
!call select_connected(i_generator,energy,mrcc_detail(1, i_i_generator),buf,subset)
|
!call select_connected(i_generator,energy,mrcc_detail(1, i_i_generator),buf,subset)
|
||||||
|
|
||||||
!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!
|
||||||
@ -108,6 +111,7 @@ subroutine run_mrcc_slave(thread,iproc,energy)
|
|||||||
!!!!!!!!!!!!!!!!!!!!!!
|
!!!!!!!!!!!!!!!!!!!!!!
|
||||||
!print *, "contrib", i_generator, contrib
|
!print *, "contrib", i_generator, contrib
|
||||||
mrcc_detail(:, i_i_generator) = contrib
|
mrcc_detail(:, i_i_generator) = contrib
|
||||||
|
if(Nindex /= 1) stop "run_mrcc_slave multiple dress not supported"
|
||||||
enddo
|
enddo
|
||||||
endif
|
endif
|
||||||
|
|
||||||
@ -117,7 +121,7 @@ subroutine run_mrcc_slave(thread,iproc,energy)
|
|||||||
call task_done_to_taskserver(zmq_to_qp_run_socket,worker_id,task_id(i))
|
call task_done_to_taskserver(zmq_to_qp_run_socket,worker_id,task_id(i))
|
||||||
end do
|
end do
|
||||||
if(ctask > 0) then
|
if(ctask > 0) then
|
||||||
call push_mrcc_results(zmq_socket_push, Nindex, index, mrcc_detail, task_id(1), ctask)
|
call push_mrcc_results(zmq_socket_push, Nindex, ind, mrcc_detail, delta_ij_loc, delta_ij_s2_loc, task_id(1), ctask)
|
||||||
mrcc_detail(:,:Nindex) = 0d0
|
mrcc_detail(:,:Nindex) = 0d0
|
||||||
! buf%cur = 0
|
! buf%cur = 0
|
||||||
end if
|
end if
|
||||||
@ -134,27 +138,34 @@ subroutine run_mrcc_slave(thread,iproc,energy)
|
|||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
|
||||||
subroutine push_mrcc_results(zmq_socket_push, N, index, mrcc_detail, task_id, ntask)
|
subroutine push_mrcc_results(zmq_socket_push, N, ind, mrcc_detail, mrcc_dress, mrcc_s2_dress, task_id, ntask)
|
||||||
use f77_zmq
|
use f77_zmq
|
||||||
use selection_types
|
|
||||||
implicit none
|
implicit none
|
||||||
|
|
||||||
integer(ZMQ_PTR), intent(in) :: zmq_socket_push
|
integer(ZMQ_PTR), intent(in) :: zmq_socket_push
|
||||||
double precision, intent(in) :: mrcc_detail(N_states, N_det_generators)
|
double precision, intent(in) :: mrcc_detail(N_states, N_det_generators)
|
||||||
integer, intent(in) :: ntask, N, index, task_id(*)
|
double precision, intent(in) :: mrcc_dress(N_states, N_det_non_ref, *)
|
||||||
integer :: rc
|
double precision, intent(in) :: mrcc_s2_dress(N_states, N_det_non_ref, *)
|
||||||
|
integer, intent(in) :: ntask, N, ind(*), task_id(*)
|
||||||
|
integer :: rc, i
|
||||||
|
|
||||||
rc = f77_zmq_send( zmq_socket_push, N, 4, ZMQ_SNDMORE)
|
rc = f77_zmq_send( zmq_socket_push, N, 4, ZMQ_SNDMORE)
|
||||||
if(rc /= 4) stop "push"
|
if(rc /= 4) stop "push"
|
||||||
|
|
||||||
rc = f77_zmq_send( zmq_socket_push, index, 4, ZMQ_SNDMORE)
|
rc = f77_zmq_send( zmq_socket_push, ind, 4*N, ZMQ_SNDMORE)
|
||||||
if(rc /= 4*N) stop "push"
|
if(rc /= 4*N) stop "push"
|
||||||
|
|
||||||
|
|
||||||
rc = f77_zmq_send( zmq_socket_push, mrcc_detail, 8*N_states*N, ZMQ_SNDMORE)
|
rc = f77_zmq_send( zmq_socket_push, mrcc_detail, 8*N_states*N, ZMQ_SNDMORE)
|
||||||
if(rc /= 8*N_states*N) stop "push"
|
if(rc /= 8*N_states*N) stop "push"
|
||||||
|
|
||||||
|
rc = f77_zmq_send( zmq_socket_push, mrcc_dress, 8*N_states*N_det_non_ref*N, ZMQ_SNDMORE)
|
||||||
|
if(rc /= 8*N_states*N_det_non_ref*N) stop "push"
|
||||||
|
|
||||||
|
rc = f77_zmq_send( zmq_socket_push, mrcc_s2_dress, 8*N_states*N_det_non_ref*N, ZMQ_SNDMORE)
|
||||||
|
if(rc /= 8*N_states*N_det_non_ref*N) stop "push"
|
||||||
|
|
||||||
|
|
||||||
rc = f77_zmq_send( zmq_socket_push, ntask, 4, ZMQ_SNDMORE)
|
rc = f77_zmq_send( zmq_socket_push, ntask, 4, ZMQ_SNDMORE)
|
||||||
if(rc /= 4) stop "push"
|
if(rc /= 4) stop "push"
|
||||||
|
|
||||||
@ -171,25 +182,41 @@ IRP_ENDIF
|
|||||||
end subroutine
|
end subroutine
|
||||||
|
|
||||||
|
|
||||||
subroutine pull_mrcc_results(zmq_socket_pull, N, index, mrcc_detail, task_id, ntask)
|
subroutine pull_mrcc_results(zmq_socket_pull, N, ind, mrcc_detail, mrcc_dress, task_id, ntask)
|
||||||
|
use dress_types
|
||||||
use f77_zmq
|
use f77_zmq
|
||||||
use selection_types
|
|
||||||
implicit none
|
implicit none
|
||||||
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
|
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
|
||||||
double precision, intent(inout) :: mrcc_detail(N_states, N_det_generators)
|
double precision, intent(inout) :: mrcc_detail(N_states, N_det_generators)
|
||||||
integer, intent(out) :: index
|
double precision, allocatable :: mrcc_dress_mwen(:,:)
|
||||||
|
type(dress_buffer), intent(inout) :: mrcc_dress(2)
|
||||||
|
integer, intent(out) :: ind(*)
|
||||||
integer, intent(out) :: N, ntask, task_id(*)
|
integer, intent(out) :: N, ntask, task_id(*)
|
||||||
integer :: rc, rn, i
|
integer :: rc, rn, i
|
||||||
|
|
||||||
|
allocate(mrcc_dress_mwen(N_states, N_det_non_ref))
|
||||||
|
|
||||||
rc = f77_zmq_recv( zmq_socket_pull, N, 4, 0)
|
rc = f77_zmq_recv( zmq_socket_pull, N, 4, 0)
|
||||||
if(rc /= 4) stop "pull"
|
if(rc /= 4) stop "pull"
|
||||||
|
|
||||||
rc = f77_zmq_recv( zmq_socket_pull, index, 4, 0)
|
rc = f77_zmq_recv( zmq_socket_pull, ind, 4, 0)
|
||||||
if(rc /= 4*N) stop "pull"
|
if(rc /= 4*N) stop "pull"
|
||||||
|
|
||||||
rc = f77_zmq_recv( zmq_socket_pull, mrcc_detail, N_states*8*N, 0)
|
rc = f77_zmq_recv( zmq_socket_pull, mrcc_detail, N_states*8*N, 0)
|
||||||
if(rc /= 8*N_states*N) stop "pull"
|
if(rc /= 8*N_states*N) stop "pull"
|
||||||
|
|
||||||
|
do i=1,N
|
||||||
|
rc = f77_zmq_recv( zmq_socket_pull, mrcc_dress_mwen, N_states*8*N_det_non_ref, 0)
|
||||||
|
if(rc /= 8*N_states*N_det_non_ref) stop "pull"
|
||||||
|
call add_to_dress_buffer(mrcc_dress(1), ind(i), mrcc_dress_mwen)
|
||||||
|
end do
|
||||||
|
|
||||||
|
do i=1,N
|
||||||
|
rc = f77_zmq_recv( zmq_socket_pull, mrcc_dress_mwen, N_states*8*N_det_non_ref, 0)
|
||||||
|
if(rc /= 8*N_states*N_det_non_ref) stop "pull"
|
||||||
|
call add_to_dress_buffer(mrcc_dress(2), ind(i), mrcc_dress_mwen)
|
||||||
|
end do
|
||||||
|
|
||||||
rc = f77_zmq_recv( zmq_socket_pull, ntask, 4, 0)
|
rc = f77_zmq_recv( zmq_socket_pull, ntask, 4, 0)
|
||||||
if(rc /= 4) stop "pull"
|
if(rc /= 4) stop "pull"
|
||||||
|
|
||||||
|
@ -1,133 +0,0 @@
|
|||||||
|
|
||||||
subroutine create_selection_buffer(N, siz, res)
|
|
||||||
use selection_types
|
|
||||||
implicit none
|
|
||||||
|
|
||||||
integer, intent(in) :: N, siz
|
|
||||||
type(selection_buffer), intent(out) :: res
|
|
||||||
|
|
||||||
allocate(res%det(N_int, 2, siz), res%val(siz))
|
|
||||||
|
|
||||||
res%val = 0d0
|
|
||||||
res%det = 0_8
|
|
||||||
res%N = N
|
|
||||||
res%mini = 0d0
|
|
||||||
res%cur = 0
|
|
||||||
end subroutine
|
|
||||||
|
|
||||||
subroutine delete_selection_buffer(b)
|
|
||||||
use selection_types
|
|
||||||
implicit none
|
|
||||||
type(selection_buffer), intent(inout) :: b
|
|
||||||
if (associated(b%det)) then
|
|
||||||
deallocate(b%det)
|
|
||||||
endif
|
|
||||||
if (associated(b%val)) then
|
|
||||||
deallocate(b%val)
|
|
||||||
endif
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
subroutine add_to_selection_buffer(b, det, val)
|
|
||||||
use selection_types
|
|
||||||
implicit none
|
|
||||||
|
|
||||||
type(selection_buffer), intent(inout) :: b
|
|
||||||
integer(bit_kind), intent(in) :: det(N_int, 2)
|
|
||||||
double precision, intent(in) :: val
|
|
||||||
integer :: i
|
|
||||||
|
|
||||||
if(val <= b%mini) then
|
|
||||||
b%cur += 1
|
|
||||||
b%det(1:N_int,1:2,b%cur) = det(1:N_int,1:2)
|
|
||||||
b%val(b%cur) = val
|
|
||||||
if(b%cur == size(b%val)) then
|
|
||||||
call sort_selection_buffer(b)
|
|
||||||
end if
|
|
||||||
end if
|
|
||||||
end subroutine
|
|
||||||
|
|
||||||
subroutine merge_selection_buffers(b1, b2)
|
|
||||||
use selection_types
|
|
||||||
implicit none
|
|
||||||
BEGIN_DOC
|
|
||||||
! Merges the selection buffers b1 and b2 into b2
|
|
||||||
END_DOC
|
|
||||||
type(selection_buffer), intent(inout) :: b1
|
|
||||||
type(selection_buffer), intent(inout) :: b2
|
|
||||||
integer(bit_kind), pointer :: detmp(:,:,:)
|
|
||||||
double precision, pointer :: val(:)
|
|
||||||
integer :: i, i1, i2, k, nmwen
|
|
||||||
if (b1%cur == 0) return
|
|
||||||
do while (b1%val(b1%cur) > b2%mini)
|
|
||||||
b1%cur = b1%cur-1
|
|
||||||
if (b1%cur == 0) then
|
|
||||||
return
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
nmwen = min(b1%N, b1%cur+b2%cur)
|
|
||||||
allocate( val(size(b1%val)), detmp(N_int, 2, size(b1%det,3)) )
|
|
||||||
i1=1
|
|
||||||
i2=1
|
|
||||||
do i=1,nmwen
|
|
||||||
if ( (i1 > b1%cur).and.(i2 > b2%cur) ) then
|
|
||||||
exit
|
|
||||||
else if (i1 > b1%cur) then
|
|
||||||
val(i) = b2%val(i2)
|
|
||||||
detmp(1:N_int,1,i) = b2%det(1:N_int,1,i2)
|
|
||||||
detmp(1:N_int,2,i) = b2%det(1:N_int,2,i2)
|
|
||||||
i2=i2+1
|
|
||||||
else if (i2 > b2%cur) then
|
|
||||||
val(i) = b1%val(i1)
|
|
||||||
detmp(1:N_int,1,i) = b1%det(1:N_int,1,i1)
|
|
||||||
detmp(1:N_int,2,i) = b1%det(1:N_int,2,i1)
|
|
||||||
i1=i1+1
|
|
||||||
else
|
|
||||||
if (b1%val(i1) <= b2%val(i2)) then
|
|
||||||
val(i) = b1%val(i1)
|
|
||||||
detmp(1:N_int,1,i) = b1%det(1:N_int,1,i1)
|
|
||||||
detmp(1:N_int,2,i) = b1%det(1:N_int,2,i1)
|
|
||||||
i1=i1+1
|
|
||||||
else
|
|
||||||
val(i) = b2%val(i2)
|
|
||||||
detmp(1:N_int,1,i) = b2%det(1:N_int,1,i2)
|
|
||||||
detmp(1:N_int,2,i) = b2%det(1:N_int,2,i2)
|
|
||||||
i2=i2+1
|
|
||||||
endif
|
|
||||||
endif
|
|
||||||
enddo
|
|
||||||
deallocate(b2%det, b2%val)
|
|
||||||
b2%det => detmp
|
|
||||||
b2%val => val
|
|
||||||
b2%mini = min(b2%mini,b2%val(b2%N))
|
|
||||||
b2%cur = nmwen
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
subroutine sort_selection_buffer(b)
|
|
||||||
use selection_types
|
|
||||||
implicit none
|
|
||||||
|
|
||||||
type(selection_buffer), intent(inout) :: b
|
|
||||||
integer, allocatable :: iorder(:)
|
|
||||||
integer(bit_kind), pointer :: detmp(:,:,:)
|
|
||||||
integer :: i, nmwen
|
|
||||||
logical, external :: detEq
|
|
||||||
if (b%cur == 0) return
|
|
||||||
nmwen = min(b%N, b%cur)
|
|
||||||
|
|
||||||
allocate(iorder(b%cur), detmp(N_int, 2, size(b%det,3)))
|
|
||||||
do i=1,b%cur
|
|
||||||
iorder(i) = i
|
|
||||||
end do
|
|
||||||
call dsort(b%val, iorder, b%cur)
|
|
||||||
do i=1, nmwen
|
|
||||||
detmp(1:N_int,1,i) = b%det(1:N_int,1,iorder(i))
|
|
||||||
detmp(1:N_int,2,i) = b%det(1:N_int,2,iorder(i))
|
|
||||||
end do
|
|
||||||
deallocate(b%det,iorder)
|
|
||||||
b%det => detmp
|
|
||||||
b%mini = min(b%mini,b%val(b%N))
|
|
||||||
b%cur = nmwen
|
|
||||||
end subroutine
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user