10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-05 11:00:10 +01:00

checkpointed mrcc_zmq

This commit is contained in:
Yann Garniron 2017-11-06 13:18:23 +01:00
parent d84fbabb8d
commit 19f3671775
3 changed files with 575 additions and 409 deletions

View File

@ -536,6 +536,288 @@ subroutine mrcc_part_dress(delta_ij_, delta_ii_,delta_ij_s2_, delta_ii_s2_,i_gen
end end
subroutine mrcc_part_dress_1c(delta_ij_, delta_ii_,delta_ij_s2_, delta_ii_s2_,i_generator,n_selected,det_buffer,Nint,key_mask,coef,contrib)
use bitmasks
implicit none
integer, intent(in) :: i_generator,n_selected, Nint
double precision, intent(inout) :: delta_ij_(N_states,N_det_non_ref)
double precision, intent(inout) :: delta_ii_(N_states)
double precision, intent(inout) :: delta_ij_s2_(N_states,N_det_non_ref)
double precision, intent(inout) :: delta_ii_s2_(N_states)
integer(bit_kind), intent(in) :: det_buffer(Nint,2,n_selected)
integer :: i,j,k,l,m
integer,allocatable :: idx_alpha(:), degree_alpha(:)
logical :: good, fullMatch
integer(bit_kind),allocatable :: tq(:,:,:)
integer :: N_tq, c_ref ,degree1, degree2, degree
double precision :: hIk, hla, hIl, sla, dIk(N_states), dka(N_states), dIa(N_states), hka
double precision, allocatable :: dIa_hla(:,:), dIa_sla(:,:)
double precision :: haj, phase, phase2
double precision :: f(N_states), ci_inv(N_states)
integer :: exc(0:2,2,2)
integer :: h1,h2,p1,p2,s1,s2
integer(bit_kind) :: tmp_det(Nint,2)
integer :: iint, ipos
integer :: i_state, k_sd, l_sd, i_I, i_alpha
integer(bit_kind),allocatable :: miniList(:,:,:)
integer(bit_kind),intent(in) :: key_mask(Nint, 2)
integer,allocatable :: idx_miniList(:)
integer :: N_miniList, ni, leng
double precision, allocatable :: hij_cache(:), sij_cache(:)
integer(bit_kind), allocatable :: microlist(:,:,:), microlist_zero(:,:,:)
integer, allocatable :: idx_microlist(:), N_microlist(:), ptr_microlist(:), idx_microlist_zero(:)
integer :: mobiles(2), smallerlist
logical, external :: detEq, is_generable
!double precision, external :: get_dij, get_dij_index
double precision :: Delta_E_inv(N_states)
double precision, intent(in) :: coef
double precision, intent(inout) :: contrib(N_states)
double precision :: sdress, hdress
if (perturbative_triples) then
PROVIDE one_anhil fock_virt_total fock_core_inactive_total one_creat
endif
leng = max(N_det_generators, N_det_non_ref)
allocate(miniList(Nint, 2, leng), tq(Nint,2,n_selected), idx_minilist(leng), hij_cache(N_det_non_ref), sij_cache(N_det_non_ref))
allocate(idx_alpha(0:psi_det_size), degree_alpha(psi_det_size))
call create_minilist_find_previous(key_mask, psi_det_generators, miniList, i_generator-1, N_miniList, fullMatch, Nint)
allocate(ptr_microlist(0:mo_tot_num*2+1), &
N_microlist(0:mo_tot_num*2) )
allocate( microlist(Nint,2,N_minilist*4), &
idx_microlist(N_minilist*4))
if(key_mask(1,1) /= 0) then
call create_microlist(miniList, N_minilist, key_mask, microlist, idx_microlist, N_microlist, ptr_microlist, Nint)
call filter_tq_micro(i_generator,n_selected,det_buffer,Nint,tq,N_tq,microlist,ptr_microlist,N_microlist,key_mask)
else
call filter_tq(i_generator,n_selected,det_buffer,Nint,tq,N_tq,miniList,N_minilist)
end if
deallocate(microlist, idx_microlist)
allocate (dIa_hla(N_states,N_det_non_ref), dIa_sla(N_states,N_det_non_ref))
! |I>
! |alpha>
if(N_tq > 0) then
call create_minilist(key_mask, psi_non_ref, miniList, idx_minilist, N_det_non_ref, N_minilist, Nint)
if(N_minilist == 0) return
if(sum(abs(key_mask(1:N_int,1))) /= 0) then
allocate(microlist_zero(Nint,2,N_minilist), idx_microlist_zero(N_minilist))
allocate( microlist(Nint,2,N_minilist*4), &
idx_microlist(N_minilist*4))
call create_microlist(miniList, N_minilist, key_mask, microlist, idx_microlist, N_microlist, ptr_microlist, Nint)
do i=0,mo_tot_num*2
do k=ptr_microlist(i),ptr_microlist(i+1)-1
idx_microlist(k) = idx_minilist(idx_microlist(k))
end do
end do
do l=1,N_microlist(0)
do k=1,Nint
microlist_zero(k,1,l) = microlist(k,1,l)
microlist_zero(k,2,l) = microlist(k,2,l)
enddo
idx_microlist_zero(l) = idx_microlist(l)
enddo
end if
end if
do i_alpha=1,N_tq
if(key_mask(1,1) /= 0) then
call getMobiles(tq(1,1,i_alpha), key_mask, mobiles, Nint)
if(N_microlist(mobiles(1)) < N_microlist(mobiles(2))) then
smallerlist = mobiles(1)
else
smallerlist = mobiles(2)
end if
do l=0,N_microlist(smallerlist)-1
microlist_zero(:,:,ptr_microlist(1) + l) = microlist(:,:,ptr_microlist(smallerlist) + l)
idx_microlist_zero(ptr_microlist(1) + l) = idx_microlist(ptr_microlist(smallerlist) + l)
end do
call get_excitation_degree_vector(microlist_zero,tq(1,1,i_alpha),degree_alpha,Nint,N_microlist(smallerlist)+N_microlist(0),idx_alpha)
do j=1,idx_alpha(0)
idx_alpha(j) = idx_microlist_zero(idx_alpha(j))
end do
else
call get_excitation_degree_vector(miniList,tq(1,1,i_alpha),degree_alpha,Nint,N_minilist,idx_alpha)
do j=1,idx_alpha(0)
idx_alpha(j) = idx_miniList(idx_alpha(j))
end do
end if
do l_sd=1,idx_alpha(0)
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 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
! |I>
do i_I=1,N_det_ref
! Find triples and quadruple grand parents
call get_excitation_degree(tq(1,1,i_alpha),psi_ref(1,1,i_I),degree1,Nint)
if (degree1 > 4) then
cycle
endif
do i_state=1,N_states
dIa(i_state) = 0.d0
enddo
! <I| <> |alpha>
do k_sd=1,idx_alpha(0)
call get_excitation_degree(psi_ref(1,1,i_I),psi_non_ref(1,1,idx_alpha(k_sd)),degree,Nint)
if (degree > 2) then
cycle
endif
! <I| /k\ |alpha>
! |l> = Exc(k -> alpha) |I>
call get_excitation(psi_non_ref(1,1,idx_alpha(k_sd)),tq(1,1,i_alpha),exc,degree2,phase,Nint)
call decode_exc(exc,degree2,h1,p1,h2,p2,s1,s2)
do k=1,N_int
tmp_det(k,1) = psi_ref(k,1,i_I)
tmp_det(k,2) = psi_ref(k,2,i_I)
enddo
logical :: ok
call apply_excitation(psi_ref(1,1,i_I), exc, tmp_det, ok, Nint)
do i_state=1,N_states
dIK(i_state) = dij(i_I, idx_alpha(k_sd), i_state)
enddo
! <I| \l/ |alpha>
do i_state=1,N_states
dka(i_state) = 0.d0
enddo
if (ok) then
do l_sd=k_sd+1,idx_alpha(0)
call get_excitation_degree(tmp_det,psi_non_ref(1,1,idx_alpha(l_sd)),degree,Nint)
if (degree == 0) then
call get_excitation(psi_ref(1,1,i_I),psi_non_ref(1,1,idx_alpha(l_sd)),exc,degree,phase2,Nint)
do i_state=1,N_states
dka(i_state) = dij(i_I, idx_alpha(l_sd), i_state) * phase * phase2
enddo
exit
endif
enddo
else if (perturbative_triples) then
! Linked
hka = hij_cache(idx_alpha(k_sd))
if (dabs(hka) > 1.d-12) then
call get_delta_e_dyall_general_mp(psi_ref(1,1,i_I),tq(1,1,i_alpha),Delta_E_inv)
do i_state=1,N_states
ASSERT (Delta_E_inv(i_state) < 0.d0)
dka(i_state) = hka / Delta_E_inv(i_state)
enddo
endif
endif
if (perturbative_triples.and. (degree2 == 1) ) then
call i_h_j(psi_ref(1,1,i_I),tmp_det,Nint,hka)
hka = hij_cache(idx_alpha(k_sd)) - hka
if (dabs(hka) > 1.d-12) then
call get_delta_e_dyall_general_mp(psi_ref(1,1,i_I),tq(1,1,i_alpha),Delta_E_inv)
do i_state=1,N_states
ASSERT (Delta_E_inv(i_state) < 0.d0)
dka(i_state) = hka / Delta_E_inv(i_state)
enddo
endif
endif
do i_state=1,N_states
dIa(i_state) = dIa(i_state) + dIk(i_state) * dka(i_state)
enddo
enddo
do i_state=1,N_states
ci_inv(i_state) = psi_ref_coef_inv(i_I,i_state)
enddo
do l_sd=1,idx_alpha(0)
k_sd = idx_alpha(l_sd)
hla = hij_cache(k_sd)
sla = sij_cache(k_sd)
do i_state=1,N_states
dIa_hla(i_state,k_sd) = dIa(i_state) * hla * coef
dIa_sla(i_state,k_sd) = dIa(i_state) * sla * coef
enddo
enddo
do i_state=1,N_states
if(dabs(psi_ref_coef(1,i_state)).ge.1.d-3)then
do l_sd=1,idx_alpha(0)
k_sd = idx_alpha(l_sd)
p1 = 1
hdress = dIa_hla(i_state,k_sd) * psi_ref_coef(i_I,i_state) / psi_ref_coef(p1,i_state)
sdress = dIa_sla(i_state,k_sd) * psi_ref_coef(i_I,i_state) / psi_ref_coef(p1,i_state)
!$OMP ATOMIC
contrib(i_state) += hdress * psi_ref_coef(p1, i_state) * psi_non_ref_coef(k_sd, i_state)
!$OMP ATOMIC
delta_ij_(i_state,k_sd) += hdress
!$OMP ATOMIC
!delta_ii_(i_state,i_I) = delta_ii_(i_state,i_I) - dIa_hla(i_state,k_sd) * ci_inv(i_state) * psi_non_ref_coef_transp(i_state,k_sd)
delta_ii_(i_state) -= hdress / psi_ref_coef(p1,i_state) * psi_non_ref_coef_transp(i_state,k_sd)
!$OMP ATOMIC
delta_ij_s2_(i_state,k_sd) += sdress
!$OMP ATOMIC
!delta_ii_s2_(i_state,i_I) = delta_ii_s2_(i_state,i_I) - dIa_sla(i_state,k_sd) * ci_inv(i_state) * psi_non_ref_coef_transp(i_state,k_sd)
delta_ii_s2_(i_state) -= sdress / psi_ref_coef(p1,i_state) * psi_non_ref_coef_transp(i_state,k_sd)
enddo
else
!stop "dress with coef < 1d-3"
delta_ii_(i_state) = 0.d0
do l_sd=1,idx_alpha(0)
k_sd = idx_alpha(l_sd)
p1 = 1
hdress = dIa_hla(i_state,k_sd) * psi_ref_coef(i_I,i_state) / psi_ref_coef(p1,i_state)
sdress = dIa_sla(i_state,k_sd) * psi_ref_coef(i_I,i_state) / psi_ref_coef(p1,i_state)
!$OMP ATOMIC
delta_ij_(i_state,k_sd) = delta_ij_(i_state,k_sd) + 0.5d0*hdress
!$OMP ATOMIC
delta_ij_s2_(i_state,k_sd) = delta_ij_s2_(i_state,k_sd) + 0.5d0*sdress
enddo
endif
enddo
enddo
enddo
deallocate (dIa_hla,dIa_sla,hij_cache,sij_cache)
deallocate(miniList, idx_miniList)
end
BEGIN_PROVIDER [ double precision, mrcc_previous_E, (N_states) ] BEGIN_PROVIDER [ double precision, mrcc_previous_E, (N_states) ]
implicit none implicit none
BEGIN_DOC BEGIN_DOC
@ -572,7 +854,7 @@ end
threshold_generators = 1d0 threshold_generators = 1d0
!errr = errr / 2d0 !errr = errr / 2d0
if(errr /= 0d0) then if(errr /= 0d0) then
errr = errr / 4d0 ! (-mrcc_E0_denominator(1) + mrcc_previous_E(1)) / 1d1 errr = errr / 2d0 ! (-mrcc_E0_denominator(1) + mrcc_previous_E(1)) / 1d1
else else
errr = 4d-4 errr = 4d-4
end if end if

View File

@ -3,6 +3,7 @@ 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, delta, delta_s2, relative_error) subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, relative_error)
use dress_types use dress_types
use f77_zmq use f77_zmq
@ -16,45 +17,19 @@ subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, relative_error)
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(N_states, N_det_non_ref)
double precision, intent(out) :: delta_s2(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(:) integer :: i, j, k, Ncp
logical, allocatable :: computed(:)
integer, allocatable :: tbc(:)
integer :: i, j, k, Ncomb, generator_per_task, i_generator_end
integer, external :: mrcc_find
double precision :: sumabove(comb_teeth), sum2above(comb_teeth), Nabove(comb_teeth)
double precision, external :: omp_get_wtime double precision, external :: omp_get_wtime
double precision :: time double precision :: time
!if (N_det < 10) then
! !call ZMQ_selection(0, mrcc)
! return
!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))
sumabove = 0d0
sum2above = 0d0
Nabove = 0d0
provide nproc fragment_first fragment_count mo_bielec_integrals_in_map mo_mono_elec_integral mrcc_weight psi_selectors provide nproc fragment_first fragment_count mo_bielec_integrals_in_map mo_mono_elec_integral mrcc_weight psi_selectors
computed = .false.
tbc(0) = first_det_of_comb - 1
do i=1, tbc(0)
tbc(i) = i
computed(i) = .true.
end do
mrcc_detail = 0d0
generator_per_task = 1
print *, '========== ================= ================= =================' print *, '========== ================= ================= ================='
print *, ' Samples Energy Stat. Error Seconds ' print *, ' Samples Energy Stat. Error Seconds '
print *, '========== ================= ================= =================' print *, '========== ================= ================= ================='
@ -62,8 +37,7 @@ subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, 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))
Ncomb=size(comb) ! call get_carlo_workbatch(Ncp, tbc, cp, cp_at, cp_N)
call get_carlo_workbatch(computed, comb, Ncomb, tbc)
do i=1,comb_teeth do i=1,comb_teeth
print *, "TOOTH", first_det_of_teeth(i+1) - first_det_of_teeth(i) print *, "TOOTH", first_det_of_teeth(i+1) - first_det_of_teeth(i)
@ -73,9 +47,9 @@ subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, 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,N_mrcc_jobs
if(tbc(i) > fragment_first) then if(mrcc_jobs(i) > fragment_first) then
write(task(ipos:ipos+20),'(I9,1X,I9,''|'')') 0, tbc(i) write(task(ipos:ipos+20),'(I9,1X,I9,''|'')') 0, mrcc_jobs(i)
ipos += 20 ipos += 20
if (ipos > 63980) then if (ipos > 63980) then
call add_task_to_taskserver(zmq_to_qp_run_socket,trim(task(1:ipos))) call add_task_to_taskserver(zmq_to_qp_run_socket,trim(task(1:ipos)))
@ -83,7 +57,7 @@ subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, relative_error)
endif endif
else else
do j=1,fragment_count do j=1,fragment_count
write(task(ipos:ipos+20),'(I9,1X,I9,''|'')') j, tbc(i) write(task(ipos:ipos+20),'(I9,1X,I9,''|'')') j, mrcc_jobs(i)
ipos += 20 ipos += 20
if (ipos > 63980) then if (ipos > 63980) then
call add_task_to_taskserver(zmq_to_qp_run_socket,trim(task(1:ipos))) call add_task_to_taskserver(zmq_to_qp_run_socket,trim(task(1:ipos)))
@ -102,7 +76,7 @@ subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, 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, db, tbc, comb, Ncomb, computed, mrcc_detail, sumabove, sum2above, Nabove, relative_error, mrcc) call mrcc_collector(E, relative_error, delta, delta_s2, mrcc)
else else
call mrcc_slave_inproc(i) call mrcc_slave_inproc(i)
endif endif
@ -110,53 +84,6 @@ subroutine ZMQ_mrcc(E, mrcc, delta, delta_s2, relative_error)
call end_parallel_job(zmq_to_qp_run_socket, 'mrcc') call end_parallel_job(zmq_to_qp_run_socket, 'mrcc')
print *, '========== ================= ================= =================' print *, '========== ================= ================= ================='
!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
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
logical, intent(in) :: computed(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), sumin(comb_teeth), Nabove(comb_teeth)
double precision, intent(inout) :: isincomb(N_det_generators)
type(dress_buffer), intent(inout) :: db(2)
integer :: i, j, dets(comb_teeth)
double precision :: myVal, myVal2, myValcur
mainLoop : do i=1,Ncomb
call get_comb(comb(i), dets, comb_teeth)
do j=1,comb_teeth
if(.not.(computed(dets(j)))) then
exit mainLoop
end if
end do
myVal = 0d0
myVal2 = 0d0
do j=comb_teeth,1,-1
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
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
Nabove(j) += 1
end do
db(1)%N += 1d0
db(2)%N += 1d0
end do mainLoop
end subroutine end subroutine
@ -168,66 +95,54 @@ subroutine mrcc_slave_inproc(i)
end end
subroutine mrcc_collector(E, db, tbc, comb, Ncomb, computed, mrcc_detail, sumabove, sum2above, Nabove, relative_error, mrcc) subroutine mrcc_collector(E, relative_error, delta, delta_s2, mrcc)
use dress_types use dress_types
use f77_zmq use f77_zmq
use bitmasks use bitmasks
implicit none implicit none
integer, intent(in) :: Ncomb double precision, intent(in) :: relative_error, E
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
logical, intent(inout) :: computed(N_det_generators)
integer, intent(in) :: tbc(0:size_tbc)
double precision, intent(inout) :: sumabove(comb_teeth), sum2above(comb_teeth), Nabove(comb_teeth)
double precision, intent(out) :: mrcc(N_states) double precision, intent(out) :: mrcc(N_states)
double precision, allocatable :: cp(:,:,:,:)
double precision, intent(out) :: delta(N_states, N_det_non_ref)
double precision, allocatable :: mrcc_mwen(:,:) double precision, intent(out) :: delta_s2(N_states, N_det_non_ref)
double precision, allocatable :: delta_loc(:,:,:), delta_det(:,:,:,:)
double precision, allocatable :: mrcc_detail(:,:)
double precision :: mrcc_mwen(N_states)
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
integer(ZMQ_PTR), external :: new_zmq_pull_socket integer(ZMQ_PTR), external :: new_zmq_pull_socket
integer(ZMQ_PTR) :: zmq_socket_pull integer(ZMQ_PTR) :: zmq_socket_pull
integer :: msg_size, rc, more integer :: more
integer :: acc, i, j, robin, N, ntask integer :: i, j, k, i_state, N, ntask
integer(bit_kind), allocatable :: det(:,:,:)
integer, allocatable :: task_id(:) integer, allocatable :: task_id(:)
integer :: Nindex integer :: Nindex
integer, allocatable :: ind(:) 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, old_tooth
double precision, external :: omp_get_wtime double precision, external :: omp_get_wtime
integer :: tooth, firstTBDcomb, orgTBDcomb integer :: cur_cp, old_cur_cp
integer, allocatable :: parts_to_get(:) integer, allocatable :: parts_to_get(:)
logical, allocatable :: actually_computed(:) logical, allocatable :: actually_computed(:)
double precision :: ncomputed
integer :: total_computed integer :: total_computed
double precision :: sumin(comb_teeth) allocate(delta_det(N_states, N_det_non_ref, 0:comb_teeth, 2))
double precision :: isincomb(N_det_generators) allocate(cp(N_states, N_det_non_ref, N_cp, 2), mrcc_detail(N_states, N_det_generators))
allocate(delta_loc(N_states, N_det_non_ref, 2))
print *, "collecture" mrcc_detail = 0d0
delta_det = 0d0
ncomputed = 0d0 !mrcc_detail = mrcc_detail / 0d0
cp = 0d0
total_computed = 0 total_computed = 0
sumin = 0d0
isincomb = 0d0
character*(512) :: task character*(512) :: task
Nabove_old = -1.d0
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(1:N_states, 1:N_det_generators) =0.d0
mrcc_mwen =0.d0
do i=1,N_det_generators
actually_computed(i) = computed(i)
enddo
parts_to_get(:) = 1 parts_to_get(:) = 1
if(fragment_first > 0) then if(fragment_first > 0) then
@ -236,176 +151,118 @@ subroutine mrcc_collector(E, db, tbc, comb, Ncomb, computed, mrcc_detail, sumabo
enddo enddo
endif endif
do i=1,tbc(0) actually_computed = .false.
actually_computed(tbc(i)) = .false.
end do
orgTBDcomb = int(Nabove(1))
firstTBDcomb = 1
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(task_id(N_det_generators), ind(db(1)%N_slot)) allocate(task_id(N_det_generators), ind(1))
more = 1 more = 1
if (time0 < 0.d0) then if (time0 < 0.d0) then
call wall_time(time0) call wall_time(time0)
endif endif
timeLast = time0 timeLast = time0
cur_cp = 0
call get_first_tooth(actually_computed, tooth) old_cur_cp = 0
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, ind, mrcc_mwen, delta_loc, task_id, ntask)
if(Nindex /= 1) stop "tried pull multiple Nindex"
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, ind(i)) += mrcc_mwen(1:N_states,i) mrcc_detail(:, ind(i)) += mrcc_mwen(:)
do j=1,N_cp !! optimizable
if(cps(ind(i), j) > 0d0) then
if(tooth_of_det(ind(i)) < cp_first_tooth(j)) stop "coef on supposedely deterministic det"
double precision :: fac
fac = cps(ind(i), j) / cps_N(j) * mrcc_weight_inv(ind(i)) * comb_step
do k=1,N_det_non_ref
do i_state=1,N_states
cp(i_state,k,j,1) += delta_loc(i_state,k,1) * fac
cp(i_state,k,j,2) += delta_loc(i_state,k,2) * fac
end do
end do
end if
end do
delta_det(:,:,tooth_of_det(ind(i)), 1) += delta_loc(:,:,1)
delta_det(:,:,tooth_of_det(ind(i)), 2) += delta_loc(:,:,2)
parts_to_get(ind(i)) -= 1 parts_to_get(ind(i)) -= 1
if(parts_to_get(ind(i)) < 0) then
print *, i, ind(i), parts_to_get(ind(i)), Nindex
print *, "PARTS ??"
print *, parts_to_get
stop "PARTS ??"
end if
if(parts_to_get(ind(i)) == 0) then if(parts_to_get(ind(i)) == 0) then
!print *, "COMPUTED", ind(i)
actually_computed(ind(i)) = .true. actually_computed(ind(i)) = .true.
!print *, "CONTRIB", ind(i), psi_non_ref_coef(ind(i),1), mrcc_detail(1, ind(i))
total_computed += 1 total_computed += 1
end if end if
end do end do
do i=1, ntask do i=1, ntask
if(task_id(i) == 0) then
print *, "Error in collector"
endif
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
timeLast = time timeLast = time
do i=1, first_det_of_teeth(1)-1 cur_cp = N_cp
if(.not.(actually_computed(i))) then if(.not. actually_computed(1)) cycle pullLoop
cycle pullLoop
do i=2,N_det_generators
if(.not. actually_computed(i)) then
cur_cp = done_cp_at(i-1)
exit
end if end if
end do end do
if(cur_cp == 0) cycle pullLoop
double precision :: E0, fco, ffco, avg, tavg, mavg, var, su, su2, meqt, eqt, prop !!!!!!!!!!!!
if(firstTBDcomb <= size(comb)) then double precision :: su, su2, eqt, avg, E0, val
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
end if
if(Nabove(1) < 5d0) cycle
E0 = sum(mrcc_detail(1,:first_det_of_teeth(tooth)-1))
if (tooth <= comb_teeth) then
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))
E0 += mrcc_detail(1,first_det_of_teeth(tooth)) * prop
avg = E0 + (sumabove(tooth) / Nabove(tooth))
eqt = sqrt(1d0 / (Nabove(tooth)-1) * abs(sum2above(tooth) / Nabove(tooth) - (sumabove(tooth)/Nabove(tooth))**2))
else
eqt = 0.d0
endif
call wall_time(time)
!if (dabs(eqt/avg) < relative_error) then
if (dabs(eqt) < relative_error .or. total_computed == N_det_generators) then
! Termination
print *, "converged", Nabove(1), first_det_of_teeth(tooth)
!mrcc(1) = avg+E
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)
else
if (Nabove(tooth) > Nabove_old) then
meqt = 0d0
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 su = 0d0
su2 = 0d0 su2 = 0d0
do j=first_det_of_teeth(i), first_det_of_teeth(i+1)-1
if(actually_computed(j)) then if(N_states > 1) stop "mrcc_stoch : N_states == 1"
tavg += (mrcc_detail(1, j))! * isincomb(j) do i=1, int(cps_N(cur_cp))
ncomputed += 1d0 !isincomb(j) !if(.not. actually_computed(i)) stop "not computed"
su2 += (mrcc_detail(1, j))**2 call get_comb_val(comb(i), mrcc_detail, cp_first_tooth(cur_cp), val)
end if !val = mrcc_detail(1, i) * mrcc_weight_inv(i) * comb_step
su += val ! cps(i, cur_cp) * val
su2 += val**2 ! cps(i, cur_cp) * val**2
end do end do
if(ncomputed /= 0) then avg = su / cps_N(cur_cp)
tavg = tavg / ncomputed * dfloat(n) eqt = dsqrt( ((su2 / cps_N(cur_cp)) - avg**2) / cps_N(cur_cp) )
su2 = su2 / ncomputed * dfloat(n) E0 = sum(mrcc_detail(1, :first_det_of_teeth(cp_first_tooth(cur_cp))-1))
var = (su2 - (tavg**2)) / ncomputed
call wall_time(time)
if (dabs(eqt) < relative_error .or. total_computed >= N_det_generators) then
! Termination
!print '(G10.3, 2X, F16.7, 2X, G16.3, 2X, F16.4, A20)', Nabove(tooth), avg+E, eqt, time-time0, ''
print *, "GREPME", cur_cp, E+E0+avg, eqt, time-time0, total_computed
call zmq_abort(zmq_to_qp_run_socket)
else else
print *, "ZERO NCOMPUTED" if (cur_cp > old_cur_cp) then
tavg = 0d0 old_cur_cp = cur_cp
su2 = 0d0 print *, "GREPME", cur_cp, E+E0+avg, eqt, time-time0, total_computed
var = 0d0 !print '(G10.3, 2X, F16.7, 2X, G16.3, 2X, F16.4, A20)', Nabove(tooth), avg+E, eqt, time-time0, ''
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)
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
end do pullLoop end do pullLoop
E0 = sum(mrcc_detail(1,:first_det_of_teeth(tooth)-1)) delta = cp(:,:,cur_cp,1)
prop = ((1d0 - dfloat(comb_teeth - tooth + 1) * comb_step) - mrcc_cweight(first_det_of_teeth(tooth)-1)) delta_s2 = cp(:,:,cur_cp,2)
prop = prop * mrcc_weight_inv(first_det_of_teeth(tooth))
E0 += mrcc_detail(1,first_det_of_teeth(tooth)) * prop do i=0, cp_first_tooth(cur_cp)-1
mrcc(1) = E + E0 + (sumabove(tooth) / Nabove(tooth)) delta += delta_det(:,:,i,1)
delta_s2 += delta_det(:,:,i,2)
end do
mrcc(1) = E
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)
end subroutine end subroutine
integer function mrcc_find(v, w, sze, imin, imax) integer function mrcc_find(v, w, sze, imin, imax)
implicit none implicit none
integer, intent(in) :: sze, imin, imax integer, intent(in) :: sze, imin, imax
@ -433,81 +290,127 @@ integer function mrcc_find(v, w, sze, imin, imax)
end function end function
BEGIN_PROVIDER [ integer, comb_teeth ] BEGIN_PROVIDER [ integer, comb_per_cp ]
&BEGIN_PROVIDER [ integer, comb_teeth ]
&BEGIN_PROVIDER [ integer, N_cps_max ]
implicit none implicit none
comb_teeth = 10 comb_teeth = 16
comb_per_cp = 64
N_cps_max = N_det_generators / comb_per_cp + 1
END_PROVIDER END_PROVIDER
BEGIN_PROVIDER [ integer, N_cp ]
subroutine get_first_tooth(computed, first_teeth) &BEGIN_PROVIDER [ double precision, cps_N, (N_cps_max) ]
&BEGIN_PROVIDER [ integer, cp_first_tooth, (N_cps_max) ]
&BEGIN_PROVIDER [ integer, done_cp_at, (N_det_generators) ]
&BEGIN_PROVIDER [ double precision, cps, (N_det_generators, N_cps_max) ]
&BEGIN_PROVIDER [ integer, N_mrcc_jobs ]
&BEGIN_PROVIDER [ integer, mrcc_jobs, (N_det_generators) ]
&BEGIN_PROVIDER [ double precision, comb, (N_det_generators) ]
! subroutine get_carlo_workbatch(Ncp, tbc, cps, done_cp_at)
implicit none implicit none
logical, intent(in) :: computed(N_det_generators) logical, allocatable :: computed(:)
integer, intent(out) :: first_teeth
integer :: i, first_det
first_det = 1
first_teeth = 1
do i=first_det_of_comb, N_det_generators
if(.not.(computed(i))) then
first_det = i
exit
end if
end do
do i=comb_teeth, 1, -1
if(first_det_of_teeth(i) < first_det) then
first_teeth = i
exit
end if
end do
end subroutine
BEGIN_PROVIDER [ integer, size_tbc ]
implicit none
BEGIN_DOC
! Size of the tbc array
END_DOC
size_tbc = (comb_teeth+1)*N_det_generators + fragment_count*fragment_first
END_PROVIDER
subroutine get_carlo_workbatch(computed, comb, Ncomb, tbc)
implicit none
integer, intent(inout) :: Ncomb
double precision, intent(out) :: comb(Ncomb)
integer, intent(inout) :: tbc(0:size_tbc)
logical, intent(inout) :: computed(N_det_generators)
integer :: i, j, last_full, dets(comb_teeth) integer :: i, j, last_full, dets(comb_teeth)
integer :: icount, n integer :: k, l, cur_cp, under_det(comb_teeth+1)
integer :: k, l
allocate(computed(N_det_generators))
cps = 0d0
cur_cp = 1
done_cp_at = 0
computed = .false.
N_mrcc_jobs = first_det_of_comb - 1
do i=1, N_mrcc_jobs
mrcc_jobs(i) = i
computed(i) = .true.
end do
l=first_det_of_comb l=first_det_of_comb
call RANDOM_NUMBER(comb) call RANDOM_NUMBER(comb)
do i=1,size(comb) do i=1,N_det_generators
comb(i) = comb(i) * comb_step comb(i) = comb(i) * comb_step
!DIR$ FORCEINLINE !DIR$ FORCEINLINE
call add_comb(comb(i), computed, tbc, size_tbc, comb_teeth) call add_comb(comb(i), computed, cps(1, cur_cp), N_mrcc_jobs, mrcc_jobs)
Ncomb = i
if (tbc(0) == N_det_generators) return if(mod(i, comb_per_cp) == 0 .or. N_mrcc_jobs == N_det_generators) then
cps(:, cur_cp+1) = cps(:, cur_cp)
!cps(:, cur_cp) = cps(:, cur_cp) / dfloat(i)
done_cp_at(N_mrcc_jobs) = cur_cp
cps_N(cur_cp) = dfloat(i)
cur_cp += 1
if (N_mrcc_jobs == N_det_generators) exit
end if
do while (computed(l)) do while (computed(l))
l=l+1 l=l+1
enddo enddo
k=tbc(0)+1 k=N_mrcc_jobs+1
tbc(k) = l mrcc_jobs(k) = l
computed(l) = .True. computed(l) = .True.
tbc(0) = k N_mrcc_jobs = k
enddo
N_cp = cur_cp
if(N_mrcc_jobs /= N_det_generators) then
stop "carlo workcarlo_workbatch"
end if
cur_cp = 0
do i=1,N_mrcc_jobs
if(done_cp_at(i) /= 0) cur_cp = done_cp_at(i)
done_cp_at(i) = cur_cp
end do end do
under_det = 0
cp_first_tooth = 0
do i=1,N_mrcc_jobs
do j=comb_teeth+1,1,-1
if(mrcc_jobs(i) <= first_det_of_teeth(j)) then
under_det(j) = under_det(j) + 1
if(under_det(j) == first_det_of_teeth(j)) then
do l=done_cp_at(i)+1, N_cp
cps(:first_det_of_teeth(j)-1, l) = 0d0
cp_first_tooth(l) = j
end do
end if
else
exit
end if
end do
end do
! end subroutine
END_PROVIDER
subroutine get_comb_val(stato, detail, first, val)
implicit none
integer, intent(in) :: first
double precision, intent(in) :: stato, detail(N_states, N_det_generators)
double precision, intent(out) :: val
double precision :: curs
integer :: j, k
integer, external :: mrcc_find
curs = 1d0 - stato
val = 0d0
do j = comb_teeth, 1, -1
!DIR$ FORCEINLINE
k = mrcc_find(curs, mrcc_cweight,size(mrcc_cweight), first_det_of_teeth(j), first_det_of_teeth(j+1))
if(k < first_det_of_teeth(first)) exit
val += detail(1, k) * mrcc_weight_inv(k) * comb_step
curs -= comb_step
end do
end subroutine end subroutine
subroutine get_comb(stato, dets)
subroutine get_comb(stato, dets, ct)
implicit none implicit none
integer, intent(in) :: ct
double precision, intent(in) :: stato double precision, intent(in) :: stato
integer, intent(out) :: dets(ct) integer, intent(out) :: dets(comb_teeth)
double precision :: curs double precision :: curs
integer :: j integer :: j
integer, external :: mrcc_find integer, external :: mrcc_find
@ -521,37 +424,41 @@ subroutine get_comb(stato, dets, ct)
end subroutine end subroutine
subroutine add_comb(comb, computed, tbc, stbc, ct) subroutine add_comb(com, computed, cp, N, tbc)
implicit none implicit none
integer, intent(in) :: stbc, ct double precision, intent(in) :: com
double precision, intent(in) :: comb integer, intent(inout) :: N
double precision, intent(inout) :: cp(N_det_non_ref)
logical, intent(inout) :: computed(N_det_generators) logical, intent(inout) :: computed(N_det_generators)
integer, intent(inout) :: tbc(0:stbc) integer, intent(inout) :: tbc(N_det_generators)
integer :: i, k, l, dets(ct) integer :: i, k, l, dets(comb_teeth)
!DIR$ FORCEINLINE !DIR$ FORCEINLINE
call get_comb(comb, dets, ct) call get_comb(com, dets)
k=tbc(0)+1 k=N+1
do i = 1, ct do i = 1, comb_teeth
l = dets(i) l = dets(i)
cp(l) += 1d0 ! mrcc_weight_inv(l) * comb_step
if(.not.(computed(l))) then if(.not.(computed(l))) then
tbc(k) = l tbc(k) = l
k = k+1 k = k+1
computed(l) = .true. computed(l) = .true.
end if end if
end do end do
tbc(0) = k-1 N = k-1
end subroutine end subroutine
BEGIN_PROVIDER [ double precision, mrcc_weight, (N_det_generators) ] BEGIN_PROVIDER [ double precision, mrcc_weight, (N_det_generators) ]
&BEGIN_PROVIDER [ double precision, mrcc_weight_inv, (N_det_generators) ]
&BEGIN_PROVIDER [ double precision, mrcc_cweight, (N_det_generators) ] &BEGIN_PROVIDER [ double precision, mrcc_cweight, (N_det_generators) ]
&BEGIN_PROVIDER [ double precision, mrcc_cweight_cache, (N_det_generators) ] &BEGIN_PROVIDER [ double precision, mrcc_cweight_cache, (N_det_generators) ]
&BEGIN_PROVIDER [ double precision, comb_step ] &BEGIN_PROVIDER [ double precision, comb_step ]
&BEGIN_PROVIDER [ integer, first_det_of_teeth, (comb_teeth+1) ] &BEGIN_PROVIDER [ integer, first_det_of_teeth, (comb_teeth+1) ]
&BEGIN_PROVIDER [ integer, first_det_of_comb ] &BEGIN_PROVIDER [ integer, first_det_of_comb ]
&BEGIN_PROVIDER [ integer, tooth_of_det, (N_det_generators) ]
implicit none implicit none
integer :: i integer :: i
double precision :: norm_left, stato double precision :: norm_left, stato
@ -608,46 +515,20 @@ end subroutine
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"
endif endif
END_PROVIDER
BEGIN_PROVIDER [ double precision, mrcc_weight_inv, (N_det_generators) ]
implicit none
BEGIN_DOC
! Inverse of mrcc_weight array
END_DOC
integer :: i
do i=1,N_det_generators do i=1,N_det_generators
mrcc_weight_inv(i) = 1.d0/mrcc_weight(i) mrcc_weight_inv(i) = 1.d0/mrcc_weight(i)
enddo enddo
tooth_of_det(:first_det_of_teeth(1)-1) = 0
do i=1,comb_teeth
tooth_of_det(first_det_of_teeth(i):first_det_of_teeth(i+1)-1) = i
end do
END_PROVIDER END_PROVIDER
@ -655,3 +536,4 @@ END_PROVIDER

View File

@ -4,7 +4,7 @@ BEGIN_PROVIDER [ integer, fragment_count ]
BEGIN_DOC BEGIN_DOC
! Number of fragments for the deterministic part ! Number of fragments for the deterministic part
END_DOC END_DOC
fragment_count = 1 ! (elec_alpha_num-n_core_orb)**2 fragment_count = 1 !! (elec_alpha_num-n_core_orb)**2
END_PROVIDER END_PROVIDER
@ -37,16 +37,16 @@ subroutine run_mrcc_slave(thread,iproc,energy)
double precision,allocatable :: delta_ij_loc(:,:,:) double precision,allocatable :: delta_ij_loc(:,:,:)
double precision,allocatable :: delta_ii_loc(:,:) double precision,allocatable :: delta_ii_loc(:,:)
double precision,allocatable :: delta_ij_s2_loc(:,:,:) !double precision,allocatable :: delta_ij_s2_loc(:,:,:)
double precision,allocatable :: delta_ii_s2_loc(:,:) !double precision,allocatable :: delta_ii_s2_loc(:,:)
integer :: h,p,n integer :: h,p,n
logical :: ok logical :: ok
double precision :: contrib(N_states) double precision :: contrib(N_states)
allocate(delta_ij_loc(N_states,N_det_non_ref,N_det_ref) & allocate(delta_ij_loc(N_states,N_det_non_ref,2) &
,delta_ii_loc(N_states,N_det_ref) & ,delta_ii_loc(N_states,2))! &
,delta_ij_s2_loc(N_states,N_det_non_ref,N_det_ref) & !,delta_ij_s2_loc(N_states,N_det_non_ref,N_det_ref) &
,delta_ii_s2_loc(N_states, N_det_ref)) !,delta_ii_s2_loc(N_states, N_det_ref))
allocate(abuf(N_int, 2, N_det_non_ref)) allocate(abuf(N_int, 2, N_det_non_ref))
@ -84,8 +84,8 @@ subroutine run_mrcc_slave(thread,iproc,energy)
i_generator = ind(i_i_generator) i_generator = ind(i_i_generator)
delta_ij_loc = 0d0 delta_ij_loc = 0d0
delta_ii_loc = 0d0 delta_ii_loc = 0d0
delta_ij_s2_loc = 0d0 !delta_ij_s2_loc = 0d0
delta_ii_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)
!!!!!!!!!!!!!!!!!!!!!! !!!!!!!!!!!!!!!!!!!!!!
@ -104,7 +104,7 @@ subroutine run_mrcc_slave(thread,iproc,energy)
n = n - 1 n = n - 1
if(n /= 0) then if(n /= 0) then
call mrcc_part_dress(delta_ij_loc, delta_ii_loc, delta_ij_s2_loc, delta_ii_s2_loc, & call mrcc_part_dress_1c(delta_ij_loc(1,1,1), delta_ii_loc(1,1), delta_ij_loc(1,1,2), delta_ii_loc(1,2), &
i_generator,n,abuf,N_int,omask,1d0,contrib) i_generator,n,abuf,N_int,omask,1d0,contrib)
endif endif
end do end do
@ -121,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, ind, mrcc_detail, delta_ij_loc, delta_ij_s2_loc, task_id(1), ctask) call push_mrcc_results(zmq_socket_push, Nindex, ind, mrcc_detail, delta_ij_loc(1,1,1), task_id(1), ctask)
mrcc_detail(:,:Nindex) = 0d0 mrcc_detail(:,:Nindex) = 0d0
! buf%cur = 0 ! buf%cur = 0
end if end if
@ -138,17 +138,18 @@ subroutine run_mrcc_slave(thread,iproc,energy)
end subroutine end subroutine
subroutine push_mrcc_results(zmq_socket_push, N, ind, mrcc_detail, mrcc_dress, mrcc_s2_dress, task_id, ntask) subroutine push_mrcc_results(zmq_socket_push, N, ind, mrcc_detail, delta_loc, task_id, ntask)
use f77_zmq use f77_zmq
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)
double precision, intent(in) :: mrcc_dress(N_states, N_det_non_ref, *) double precision, intent(in) :: delta_loc(N_states, N_det_non_ref, 2)
double precision, intent(in) :: mrcc_s2_dress(N_states, N_det_non_ref, *)
integer, intent(in) :: ntask, N, ind(*), task_id(*) integer, intent(in) :: ntask, N, ind(*), task_id(*)
integer :: rc, i integer :: rc, i
if(N/=1) stop "mrcc_stoch, tried to push N>1"
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"
@ -159,10 +160,10 @@ subroutine push_mrcc_results(zmq_socket_push, N, ind, mrcc_detail, mrcc_dress, m
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) rc = f77_zmq_send( zmq_socket_push, delta_loc(1,1,1), 8*N_states*N_det_non_ref*N, ZMQ_SNDMORE)
if(rc /= 8*N_states*N_det_non_ref*N) stop "push" 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) rc = f77_zmq_send( zmq_socket_push, delta_loc(1,1,2), 8*N_states*N_det_non_ref*N, ZMQ_SNDMORE)
if(rc /= 8*N_states*N_det_non_ref*N) stop "push" if(rc /= 8*N_states*N_det_non_ref*N) stop "push"
@ -182,14 +183,14 @@ IRP_ENDIF
end subroutine end subroutine
subroutine pull_mrcc_results(zmq_socket_pull, N, ind, mrcc_detail, mrcc_dress, task_id, ntask) subroutine pull_mrcc_results(zmq_socket_pull, N, ind, mrcc_detail, delta_loc, task_id, ntask)
use dress_types use dress_types
use f77_zmq use f77_zmq
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)
double precision, intent(inout) :: delta_loc(N_states, N_det_non_ref, 2)
double precision, allocatable :: mrcc_dress_mwen(:,:) double precision, allocatable :: mrcc_dress_mwen(:,:)
type(dress_buffer), intent(inout) :: mrcc_dress(2)
integer, intent(out) :: ind(*) 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
@ -198,6 +199,7 @@ subroutine pull_mrcc_results(zmq_socket_pull, N, ind, mrcc_detail, mrcc_dress, t
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"
if(N /= 1) stop "mrcc : pull with N>1 not supported"
rc = f77_zmq_recv( zmq_socket_pull, ind, 4, 0) rc = f77_zmq_recv( zmq_socket_pull, ind, 4, 0)
if(rc /= 4*N) stop "pull" if(rc /= 4*N) stop "pull"
@ -205,17 +207,17 @@ subroutine pull_mrcc_results(zmq_socket_pull, N, ind, mrcc_detail, mrcc_dress, t
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 !do i=1,N
rc = f77_zmq_recv( zmq_socket_pull, mrcc_dress_mwen, N_states*8*N_det_non_ref, 0) rc = f77_zmq_recv( zmq_socket_pull, delta_loc(1,1,1), N_states*8*N_det_non_ref, 0)
if(rc /= 8*N_states*N_det_non_ref) stop "pull" if(rc /= 8*N_states*N_det_non_ref) stop "pull"
call add_to_dress_buffer(mrcc_dress(1), ind(i), mrcc_dress_mwen) !call add_to_dress_buffer(mrcc_dress(1), ind(i), mrcc_dress_mwen)
end do !end do
do i=1,N !do i=1,N
rc = f77_zmq_recv( zmq_socket_pull, mrcc_dress_mwen, N_states*8*N_det_non_ref, 0) rc = f77_zmq_recv( zmq_socket_pull, delta_loc(1,1,2), N_states*8*N_det_non_ref, 0)
if(rc /= 8*N_states*N_det_non_ref) stop "pull" if(rc /= 8*N_states*N_det_non_ref) stop "pull"
call add_to_dress_buffer(mrcc_dress(2), ind(i), mrcc_dress_mwen) !call add_to_dress_buffer(mrcc_dress(2), ind(i), mrcc_dress_mwen)
end do !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"