10
0
mirror of https://github.com/LCPQ/quantum_package synced 2025-01-12 14:08:30 +01:00
quantum_package/plugins/mrcepa0/dressing_slave.irp.f

617 lines
20 KiB
Fortran
Raw Normal View History

2016-04-29 16:28:12 +02:00
subroutine mrsc2_dressing_slave_tcp(i)
implicit none
integer, intent(in) :: i
BEGIN_DOC
! Task for parallel MR-SC2
END_DOC
call mrsc2_dressing_slave(0,i)
end
subroutine mrsc2_dressing_slave_inproc(i)
implicit none
integer, intent(in) :: i
BEGIN_DOC
! Task for parallel MR-SC2
END_DOC
call mrsc2_dressing_slave(1,i)
end
subroutine mrsc2_dressing_slave(thread,iproc)
use f77_zmq
implicit none
BEGIN_DOC
! Task for parallel MR-SC2
END_DOC
integer, intent(in) :: thread, iproc
! integer :: j,l
integer :: rc
integer :: worker_id, task_id
character*(512) :: task
integer(ZMQ_PTR),external :: new_zmq_to_qp_run_socket
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
integer(ZMQ_PTR), external :: new_zmq_push_socket
integer(ZMQ_PTR) :: zmq_socket_push
2016-11-18 19:17:34 +01:00
double precision, allocatable :: delta(:,:,:), delta_s2(:,:,:)
2016-04-29 16:28:12 +02:00
2017-06-26 20:35:07 +02:00
integer, allocatable :: hp(:,:)
2016-04-29 16:28:12 +02:00
2017-10-06 13:05:57 +02:00
integer :: i_state, i, i_I, J, k, k2, k1, kk, ll, m, l, deg, ni, m2
2016-05-26 13:52:48 +02:00
integer :: n(2)
2016-04-29 16:28:12 +02:00
integer :: p1,p2,h1,h2,s1,s2, blok, I_s, J_s, kn
logical :: ok
2017-10-06 13:05:57 +02:00
double precision :: phase_ia, phase_Ik, phase_Jl, phase_Ji, phase_la, phase_ka, phase_tmp
double precision :: Hka, Hla, Ska, Sla, tmp
2016-04-29 16:28:12 +02:00
double precision :: diI, hIi, hJi, delta_JI, dkI, HkI, ci_inv(N_states), cj_inv(N_states)
2016-11-18 19:17:34 +01:00
double precision :: contrib, contrib_s2, wall, iwall
2017-10-06 13:05:57 +02:00
integer, dimension(0:2,2,2) :: exc_iI, exc_Ik, exc_IJ, exc
2016-04-29 16:28:12 +02:00
integer(bit_kind) :: det_tmp(N_int, 2), det_tmp2(N_int, 2), inac, virt
integer, external :: get_index_in_psi_det_sorted_bit, searchDet, detCmp
2017-10-06 13:05:57 +02:00
logical, external :: is_in_wavefunction
2016-05-26 13:52:48 +02:00
integer,allocatable :: komon(:)
2016-04-29 16:28:12 +02:00
logical :: komoned
2017-11-29 15:15:10 +01:00
integer, external :: connect_to_taskserver, disconnect_from_taskserver
2016-07-06 15:43:21 +02:00
!double precision, external :: get_dij
2016-04-29 16:28:12 +02:00
2017-11-29 15:15:10 +01:00
2016-04-29 16:28:12 +02:00
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
2017-11-29 15:15:10 +01:00
if (connect_to_taskserver(zmq_to_qp_run_socket,worker_id,thread) == -1) then
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
return
endif
2016-04-29 16:28:12 +02:00
2017-11-29 15:15:10 +01:00
zmq_socket_push = new_zmq_push_socket(thread)
2016-04-29 16:28:12 +02:00
2017-10-06 13:05:57 +02:00
allocate (delta(N_states,0:N_det_non_ref, 2))
allocate (delta_s2(N_states,0:N_det_non_ref, 2))
2016-05-26 13:52:48 +02:00
allocate(komon(0:N_det_non_ref))
2016-04-29 16:28:12 +02:00
2017-06-26 20:35:07 +02:00
allocate(hp(2,N_det_non_ref))
do i=1,N_det_non_ref
call getHP(psi_non_ref(1,1,i), HP(1,i), HP(2,i), N_int)
end do
2016-04-29 16:28:12 +02:00
do
2017-11-29 15:15:10 +01:00
integer, external :: get_task_from_taskserver
if (get_task_from_taskserver(zmq_to_qp_run_socket,worker_id, task_id, task) == -1) then
exit
endif
2016-04-29 16:28:12 +02:00
if (task_id == 0) exit
read (task,*) i_I, J, k1, k2
do i_state=1, N_states
ci_inv(i_state) = 1.d0 / psi_ref_coef(i_I,i_state)
cj_inv(i_state) = 1.d0 / psi_ref_coef(J,i_state)
end do
!delta = 0.d0
2016-11-18 19:17:34 +01:00
!delta_s2 = 0.d0
2016-04-29 16:28:12 +02:00
n = 0
delta(:,0,:) = 0d0
delta(:,:nlink(J),1) = 0d0
delta(:,:nlink(i_I),2) = 0d0
2016-11-18 19:17:34 +01:00
delta_s2(:,0,:) = 0d0
delta_s2(:,:nlink(J),1) = 0d0
delta_s2(:,:nlink(i_I),2) = 0d0
2016-04-29 16:28:12 +02:00
komon(0) = 0
komoned = .false.
do kk = k1, k2
k = det_cepa0_idx(linked(kk, i_I))
blok = blokMwen(kk, i_I)
2017-10-06 13:05:57 +02:00
call get_excitation(psi_ref(1,1,i_I),psi_non_ref(1,1,k),exc_Ik,deg,phase_Ik,N_int)
2016-04-29 16:28:12 +02:00
if(J /= i_I) then
call apply_excitation(psi_ref(1,1,J),exc_Ik,det_tmp2,ok,N_int)
if(.not. ok) cycle
l = searchDet(det_cepa0(1,1,cepa0_shortcut(blok)), det_tmp2, cepa0_shortcut(blok+1)-cepa0_shortcut(blok), N_int)
if(l == -1) cycle
ll = cepa0_shortcut(blok)-1+l
l = det_cepa0_idx(ll)
ll = child_num(ll, J)
else
l = k
ll = kk
end if
if(.not. komoned) then
m = 0
m2 = 0
do while(m < nlink(i_I) .and. m2 < nlink(J))
m += 1
m2 += 1
if(linked(m, i_I) < linked(m2, J)) then
m2 -= 1
cycle
else if(linked(m, i_I) > linked(m2, J)) then
m -= 1
cycle
end if
i = det_cepa0_idx(linked(m, i_I))
2016-11-18 19:17:34 +01:00
if(h_cache(J,i) == 0.d0) cycle
if(h_cache(i_I,i) == 0.d0) cycle
2017-10-06 13:05:57 +02:00
2016-04-29 16:28:12 +02:00
komon(0) += 1
kn = komon(0)
komon(kn) = i
end do
komoned = .true.
end if
do m = 1, komon(0)
i = komon(m)
2016-05-03 11:34:03 +02:00
2016-04-29 16:28:12 +02:00
call apply_excitation(psi_non_ref(1,1,i),exc_Ik,det_tmp,ok,N_int)
if(.not. ok) cycle
2016-05-03 17:55:41 +02:00
if(HP(1,i) + HP(1,k) <= 2 .and. HP(2,i) + HP(2,k) <= 2) then
2017-10-06 13:05:57 +02:00
if(is_in_wavefunction(det_tmp, N_int)) cycle
2016-05-03 17:55:41 +02:00
end if
2017-10-06 13:05:57 +02:00
call i_h_j_phase_out(psi_non_ref(1,1,i), det_tmp, N_int, tmp, phase_ia,exc, deg)
call i_h_j_phase_out(psi_ref(1,1,i_I), psi_non_ref(1,1,k), N_int, tmp, phase_ik,exc, deg)
call i_h_j_phase_out(psi_non_ref(1,1,l), det_tmp, N_int, Hla, phase_la,exc,deg)
call get_s2(psi_non_ref(1,1,l), det_tmp, N_int, Sla)
2016-04-29 16:28:12 +02:00
do i_state = 1, N_states
2017-10-06 13:05:57 +02:00
contrib = dij(i_I, k, i_state) * dij(i_I, i, i_state) * Hla * phase_ia * phase_ik
contrib_s2 = dij(i_I, k, i_state) * dij(i_I, i, i_state) * Sla *phase_ia * phase_ik
2016-04-29 16:28:12 +02:00
delta(i_state,ll,1) += contrib
2016-11-18 19:17:34 +01:00
delta_s2(i_state,ll,1) += contrib_s2
2016-04-29 16:28:12 +02:00
if(dabs(psi_ref_coef(i_I,i_state)).ge.5.d-5) then
delta(i_state,0,1) -= contrib * ci_inv(i_state) * psi_non_ref_coef(l,i_state)
2016-11-18 19:17:34 +01:00
delta_s2(i_state,0,1) -= contrib_s2 * ci_inv(i_state) * psi_non_ref_coef(l,i_state)
2016-04-29 16:28:12 +02:00
endif
if(I_i == J) cycle
2017-10-06 13:05:57 +02:00
call i_h_j_phase_out(psi_non_ref(1,1,k), det_tmp, N_int, Hka, phase_ka,exc,deg)
call get_s2(psi_non_ref(1,1,k), det_tmp, N_int, Ska)
call i_h_j_phase_out(psi_ref(1,1,J), psi_non_ref(1,1,l), N_int, tmp, phase_jl,exc, deg)
contrib = dij(J, l, i_state) * dij(J, i, i_state) * Hka* phase_ia * phase_jl
contrib_s2 = dij(J, l, i_state) * dij(J, i, i_state) * Ska*phase_ia*phase_jl
2016-04-29 16:28:12 +02:00
delta(i_state,kk,2) += contrib
2016-11-18 19:17:34 +01:00
delta_s2(i_state,kk,2) += contrib_s2
2016-04-29 16:28:12 +02:00
if(dabs(psi_ref_coef(J,i_state)).ge.5.d-5) then
delta(i_state,0,2) -= contrib * cj_inv(i_state) * psi_non_ref_coef(k,i_state)
2016-11-18 19:17:34 +01:00
delta_s2(i_state,0,2) -= contrib_s2 * cj_inv(i_state) * psi_non_ref_coef(k,i_state)
2016-04-29 16:28:12 +02:00
end if
enddo !i_state
end do ! while
end do ! kk
2017-10-06 13:05:57 +02:00
call push_mrsc2_results(zmq_socket_push, I_i, J, delta, delta_s2, task_id)
2017-11-29 15:15:10 +01:00
integer, external :: task_done_to_taskserver
if (task_done_to_taskserver(zmq_to_qp_run_socket,worker_id,task_id) == -1) then
stop 'Unable to send task_done to server'
endif
2016-04-29 16:28:12 +02:00
enddo
deallocate(delta)
2017-12-05 18:54:10 +01:00
if (disconnect_from_taskserver(zmq_to_qp_run_socket,worker_id) == -1) then
2017-11-29 15:15:10 +01:00
continue
endif
2016-04-29 16:28:12 +02:00
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
call end_zmq_push_socket(zmq_socket_push,thread)
end
2016-11-18 19:17:34 +01:00
subroutine push_mrsc2_results(zmq_socket_push, I_i, J, delta, delta_s2, task_id)
2016-04-29 16:28:12 +02:00
use f77_zmq
implicit none
BEGIN_DOC
! Push integrals in the push socket
END_DOC
integer, intent(in) :: i_I, J
integer(ZMQ_PTR), intent(in) :: zmq_socket_push
2016-05-26 13:52:48 +02:00
double precision,intent(inout) :: delta(N_states, 0:N_det_non_ref, 2)
2016-11-18 19:17:34 +01:00
double precision,intent(inout) :: delta_s2(N_states, 0:N_det_non_ref, 2)
2016-04-29 16:28:12 +02:00
integer, intent(in) :: task_id
integer :: rc , i_state, i, kk, li
2016-05-26 13:52:48 +02:00
integer,allocatable :: idx(:,:)
2016-07-19 15:00:20 +02:00
integer :: n(2)
2016-04-29 16:28:12 +02:00
logical :: ok
2016-05-26 13:52:48 +02:00
allocate(idx(N_det_non_ref,2))
2016-04-29 16:28:12 +02:00
rc = f77_zmq_send( zmq_socket_push, i_I, 4, ZMQ_SNDMORE)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, i_I, 4, ZMQ_SNDMORE)'
stop 'error'
endif
rc = f77_zmq_send( zmq_socket_push, J, 4, ZMQ_SNDMORE)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, J, 4, ZMQ_SNDMORE)'
stop 'error'
endif
do kk=1,2
n(kk)=0
if(kk == 1) li = nlink(j)
if(kk == 2) li = nlink(i_I)
do i=1, li
ok = .false.
do i_state=1,N_states
if(delta(i_state, i, kk) /= 0d0) then
ok = .true.
exit
end if
end do
if(ok) then
n(kk) += 1
! idx(n,kk) = i
if(kk == 1) then
idx(n(1),1) = det_cepa0_idx(linked(i, J))
else
idx(n(2),2) = det_cepa0_idx(linked(i, i_I))
end if
do i_state=1, N_states
delta(i_state, n(kk), kk) = delta(i_state, i, kk)
end do
end if
end do
rc = f77_zmq_send( zmq_socket_push, n(kk), 4, ZMQ_SNDMORE)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, n, 4, ZMQ_SNDMORE)'
stop 'error'
endif
if(n(kk) /= 0) then
rc = f77_zmq_send( zmq_socket_push, delta(1,0,kk), (n(kk)+1)*8*N_states, ZMQ_SNDMORE) ! delta(1,0,1) = delta_I delta(1,0,2) = delta_J
if (rc /= (n(kk)+1)*8*N_states) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, delta, (n(kk)+1)*8*N_states, ZMQ_SNDMORE)'
stop 'error'
endif
2016-11-18 19:17:34 +01:00
rc = f77_zmq_send( zmq_socket_push, delta_s2(1,0,kk), (n(kk)+1)*8*N_states, ZMQ_SNDMORE) ! delta_s2(1,0,1) = delta_I delta_s2(1,0,2) = delta_J
if (rc /= (n(kk)+1)*8*N_states) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, delta_s2, (n(kk)+1)*8*N_states, ZMQ_SNDMORE)'
stop 'error'
endif
2016-04-29 16:28:12 +02:00
rc = f77_zmq_send( zmq_socket_push, idx(1,kk), n(kk)*4, ZMQ_SNDMORE)
if (rc /= n(kk)*4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, delta, 8*n(kk), ZMQ_SNDMORE)'
stop 'error'
endif
end if
end do
rc = f77_zmq_send( zmq_socket_push, task_id, 4, 0)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, task_id, 4, 0)'
stop 'error'
endif
2017-02-01 21:07:26 +01:00
! Activate is zmq_socket_push is a REQ
2017-05-16 16:31:35 +02:00
IRP_IF ZMQ_PUSH
IRP_ELSE
integer :: idummy
rc = f77_zmq_recv( zmq_socket_push, idummy, 4, 0)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_push, idummy, 4, 0)'
stop 'error'
endif
IRP_ENDIF
2016-04-29 16:28:12 +02:00
end
2016-11-18 19:17:34 +01:00
subroutine pull_mrsc2_results(zmq_socket_pull, I_i, J, n, idx, delta, delta_s2, task_id)
2016-04-29 16:28:12 +02:00
use f77_zmq
implicit none
BEGIN_DOC
! Push integrals in the push socket
END_DOC
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
integer, intent(out) :: i_I, J, n(2)
double precision, intent(inout) :: delta(N_states, 0:N_det_non_ref, 2)
2016-11-18 19:17:34 +01:00
double precision, intent(inout) :: delta_s2(N_states, 0:N_det_non_ref, 2)
2016-04-29 16:28:12 +02:00
integer, intent(out) :: task_id
integer :: rc , i, kk
2016-05-26 13:52:48 +02:00
integer,intent(inout) :: idx(N_det_non_ref,2)
2016-04-29 16:28:12 +02:00
logical :: ok
2016-05-26 13:52:48 +02:00
2016-04-29 16:28:12 +02:00
rc = f77_zmq_recv( zmq_socket_pull, i_I, 4, ZMQ_SNDMORE)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, i_I, 4, ZMQ_SNDMORE)'
stop 'error'
endif
rc = f77_zmq_recv( zmq_socket_pull, J, 4, ZMQ_SNDMORE)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, J, 4, ZMQ_SNDMORE)'
stop 'error'
endif
do kk = 1, 2
rc = f77_zmq_recv( zmq_socket_pull, n(kk), 4, ZMQ_SNDMORE)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, n, 4, ZMQ_SNDMORE)'
stop 'error'
endif
if(n(kk) /= 0) then
rc = f77_zmq_recv( zmq_socket_pull, delta(1,0,kk), (n(kk)+1)*8*N_states, ZMQ_SNDMORE)
if (rc /= (n(kk)+1)*8*N_states) then
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, delta, (n(kk)+1)*8*N_states, ZMQ_SNDMORE)'
stop 'error'
endif
2016-11-18 19:17:34 +01:00
rc = f77_zmq_recv( zmq_socket_pull, delta_s2(1,0,kk), (n(kk)+1)*8*N_states, ZMQ_SNDMORE)
if (rc /= (n(kk)+1)*8*N_states) then
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, delta_s2, (n(kk)+1)*8*N_states, ZMQ_SNDMORE)'
stop 'error'
endif
2016-04-29 16:28:12 +02:00
rc = f77_zmq_recv( zmq_socket_pull, idx(1,kk), n(kk)*4, ZMQ_SNDMORE)
if (rc /= n(kk)*4) then
2016-11-18 19:17:34 +01:00
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, idx(1,kk), n(kk)*4, ZMQ_SNDMORE)'
2016-04-29 16:28:12 +02:00
stop 'error'
endif
end if
end do
rc = f77_zmq_recv( zmq_socket_pull, task_id, 4, 0)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_recv( zmq_socket_pull, task_id, 4, 0)'
stop 'error'
endif
2017-02-01 21:07:26 +01:00
! Activate is zmq_socket_pull is a REP
2017-05-16 16:31:35 +02:00
IRP_IF ZMQ_PUSH
IRP_ELSE
integer :: idummy
rc = f77_zmq_send( zmq_socket_pull, idummy, 4, 0)
if (rc /= 4) then
print *, irp_here, 'f77_zmq_send( zmq_socket_pull, idummy, 4, 0)'
stop 'error'
endif
IRP_ENDIF
2016-04-29 16:28:12 +02:00
end
subroutine mrsc2_dressing_collector(zmq_socket_pull,delta_ij_,delta_ij_s2_)
2016-04-29 16:28:12 +02:00
use f77_zmq
implicit none
BEGIN_DOC
! Collects results from the AO integral calculation
END_DOC
double precision,intent(inout) :: delta_ij_(N_states,N_det_non_ref)
double precision,intent(inout) :: delta_ij_s2_(N_states,N_det_non_ref)
2017-11-29 15:15:10 +01:00
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
2016-04-29 16:28:12 +02:00
! integer :: j,l
integer :: rc
2016-11-18 19:17:34 +01:00
double precision, allocatable :: delta(:,:,:), delta_s2(:,:,:)
2016-04-29 16:28:12 +02:00
integer(ZMQ_PTR),external :: new_zmq_to_qp_run_socket
integer(ZMQ_PTR) :: zmq_to_qp_run_socket
integer(ZMQ_PTR), external :: new_zmq_pull_socket
integer*8 :: control, accu
integer :: task_id, more
integer :: I_i, J, l, i_state, n(2), kk
2016-05-26 13:52:48 +02:00
integer,allocatable :: idx(:,:)
2016-04-29 16:28:12 +02:00
delta_ij_(:,:) = 0d0
delta_ij_s2_(:,:) = 0d0
2016-04-29 16:28:12 +02:00
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
2016-11-18 19:17:34 +01:00
allocate ( delta(N_states,0:N_det_non_ref,2), delta_s2(N_states,0:N_det_non_ref,2) )
2016-05-26 13:52:48 +02:00
double precision :: c0(N_states)
do i_state=1,N_states
c0(i_state) = 1.d0/psi_coef(dressed_column_idx(i_state),i_state)
enddo
2016-05-26 13:52:48 +02:00
allocate(idx(N_det_non_ref,2))
2016-04-29 16:28:12 +02:00
more = 1
do while (more == 1)
2016-05-26 13:52:48 +02:00
2016-11-18 19:17:34 +01:00
call pull_mrsc2_results(zmq_socket_pull, I_i, J, n, idx, delta, delta_s2, task_id)
2016-04-29 16:28:12 +02:00
do l=1, n(1)
do i_state=1,N_states
2018-06-27 15:20:33 +02:00
delta_ij_(i_state,idx(l,1)) += delta(i_state,l,1) * psi_ref_coef(i_I,i_state)
delta_ij_s2_(i_state,idx(l,1)) += delta_s2(i_state,l,1) * psi_ref_coef(i_I,i_state)
2016-04-29 16:28:12 +02:00
end do
end do
do l=1, n(2)
do i_state=1,N_states
2018-06-27 15:20:33 +02:00
delta_ij_(i_state,idx(l,2)) += delta(i_state,l,2) * psi_ref_coef(J,i_state)
delta_ij_s2_(i_state,idx(l,2)) += delta_s2(i_state,l,2) * psi_ref_coef(J,i_state)
2016-04-29 16:28:12 +02:00
end do
end do
if (task_id /= 0) then
2017-11-29 15:15:10 +01:00
integer, external :: zmq_delete_task
if (zmq_delete_task(zmq_to_qp_run_socket,zmq_socket_pull,task_id,more) == -1) then
stop 'Unable to delete task'
endif
2016-04-29 16:28:12 +02:00
endif
enddo
2016-11-18 19:17:34 +01:00
deallocate( delta, delta_s2 )
2016-04-29 16:28:12 +02:00
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
end
BEGIN_PROVIDER [ double precision, delta_ij_old, (N_states,N_det_non_ref) ]
&BEGIN_PROVIDER [ double precision, delta_ij_s2_old, (N_states,N_det_non_ref) ]
2016-04-29 16:28:12 +02:00
implicit none
integer :: i_state, i, i_I, J, k, kk, degree, degree2, m, l, deg, ni, m2
integer :: p1,p2,h1,h2,s1,s2, blok, I_s, J_s, nex, nzer, ntot
! integer, allocatable :: linked(:,:), blokMwen(:, :), nlink(:)
logical :: ok
double precision :: phase_iI, phase_Ik, phase_Jl, phase_Ji, phase_al, diI, hIi, hJi, delta_JI, dkI(N_states), HkI, ci_inv(N_states), dia_hla(N_states)
double precision :: contrib, wall, iwall ! , searchance(N_det_ref)
integer, dimension(0:2,2,2) :: exc_iI, exc_Ik, exc_IJ
integer(bit_kind) :: det_tmp(N_int, 2), det_tmp2(N_int, 2), inac, virt
integer, external :: get_index_in_psi_det_sorted_bit, searchDet, detCmp
logical, external :: is_in_wavefunction, isInCassd, detEq
character*(512) :: task
2017-11-29 15:15:10 +01:00
integer(ZMQ_PTR) :: zmq_to_qp_run_socket, zmq_socket_pull
2016-04-29 16:28:12 +02:00
integer :: KKsize = 1000000
integer, external :: add_task_to_taskserver
2016-04-29 16:28:12 +02:00
2017-11-29 15:15:10 +01:00
call new_parallel_job(zmq_to_qp_run_socket,zmq_socket_pull,'mrsc2')
2016-04-29 16:28:12 +02:00
call wall_time(iwall)
! allocate(linked(N_det_non_ref, N_det_ref), blokMwen(N_det_non_ref, N_det_ref), nlink(N_det_ref))
! searchance = 0d0
! do J = 1, N_det_ref
! nlink(J) = 0
! do blok=1,cepa0_shortcut(0)
! do k=cepa0_shortcut(blok), cepa0_shortcut(blok+1)-1
! call get_excitation_degree(psi_ref(1,1,J),det_cepa0(1,1,k),degree,N_int)
! if(degree <= 2) then
! nlink(J) += 1
! linked(nlink(J),J) = k
! blokMwen(nlink(J),J) = blok
! searchance(J) += 1d0 + log(dfloat(cepa0_shortcut(blok+1) - cepa0_shortcut(blok)))
! end if
! end do
! end do
! end do
! stop
2016-07-19 15:00:20 +02:00
nzer = 0
ntot = 0
2016-04-29 16:28:12 +02:00
do nex = 3, 0, -1
print *, "los ",nex
do I_s = N_det_ref, 1, -1
! if(mod(I_s,1) == 0) then
! call wall_time(wall)
! wall = wall-iwall
! print *, I_s, "/", N_det_ref, wall * (dfloat(N_det_ref) / dfloat(I_s)), wall, wall * (dfloat(N_det_ref) / dfloat(I_s))-wall
! end if
do J_s = 1, I_s
call get_excitation_degree(psi_ref(1,1,J_s), psi_ref(1,1,I_s), degree, N_int)
if(degree /= nex) cycle
if(nex == 3) nzer = nzer + 1
ntot += 1
! if(degree > 3) then
! deg += 1
! cycle
! else if(degree == -10) then
! KKsize = 100000
! else
! KKsize = 1000000
! end if
if(searchance(I_s) < searchance(J_s)) then
i_I = I_s
J = J_s
else
i_I = J_s
J = I_s
end if
KKsize = nlink(1)
if(nex == 0) KKsize = int(float(nlink(1)) / float(nlink(i_I)) * (float(nlink(1)) / 64d0))
!if(KKsize == 0) stop "ZZEO"
do kk = 1 , nlink(i_I), KKsize
write(task,*) I_i, J, kk, int(min(kk+KKsize-1, nlink(i_I)))
2017-11-29 15:15:10 +01:00
if (add_task_to_taskserver(zmq_to_qp_run_socket,task) == -1) then
stop 'Unable to add task to task server'
endif
2016-04-29 16:28:12 +02:00
end do
! do kk = 1 , nlink(i_I)
! k = linked(kk,i_I)
! blok = blokMwen(kk,i_I)
! write(task,*) I_i, J, k, blok
2017-11-29 15:15:10 +01:00
! if (add_task_to_taskserver(zmq_to_qp_run_socket,task) == -1) then
! stop 'Unable to add task to task server'
! endif
2016-04-29 16:28:12 +02:00
!
! enddo !kk
enddo !J
enddo !I
end do ! nex
print *, "tasked"
! integer(ZMQ_PTR) ∷ collector_thread
! external ∷ ao_bielec_integrals_in_map_collector
! rc = pthread_create(collector_thread, mrsc2_dressing_collector)
print *, nzer, ntot, float(nzer) / float(ntot)
2016-05-04 17:30:55 +02:00
provide nproc
2017-11-29 15:15:10 +01:00
!$OMP PARALLEL DEFAULT(none) &
!$OMP SHARED(delta_ij_old,delta_ij_s2_old,zmq_socket_pull)&
2017-11-29 15:15:10 +01:00
!$OMP PRIVATE(i) NUM_THREADS(nproc+1)
2016-04-29 16:28:12 +02:00
i = omp_get_thread_num()
if (i==0) then
call mrsc2_dressing_collector(zmq_socket_pull,delta_ij_old,delta_ij_s2_old)
2016-04-29 16:28:12 +02:00
else
call mrsc2_dressing_slave_inproc(i)
endif
!$OMP END PARALLEL
! rc = pthread_join(collector_thread)
2017-11-29 15:15:10 +01:00
call end_parallel_job(zmq_to_qp_run_socket, zmq_socket_pull, 'mrsc2')
2016-04-29 16:28:12 +02:00
END_PROVIDER