10
0
mirror of https://github.com/LCPQ/quantum_package synced 2024-07-03 18:05:59 +02:00
quantum_package/plugins/dress_zmq/run_dress_slave.irp.f

302 lines
9.3 KiB
Fortran
Raw Normal View History

2018-03-30 18:16:00 +02:00
use bitmasks
2017-12-15 16:21:04 +01:00
BEGIN_PROVIDER [ integer, fragment_count ]
implicit none
BEGIN_DOC
! Number of fragments for the deterministic part
END_DOC
fragment_count = 1
END_PROVIDER
subroutine run_dress_slave(thread,iproc,energy)
use f77_zmq
implicit none
double precision, intent(in) :: energy(N_states_diag)
integer, intent(in) :: thread, iproc
2018-04-27 12:41:39 +02:00
integer :: rc, i, subset, i_generator(60)
2017-12-15 16:21:04 +01:00
integer :: worker_id, task_id, ctask, ltask
2018-04-27 12:41:39 +02:00
character*(5120) :: task
2017-12-15 16:21:04 +01: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_push_socket
integer(ZMQ_PTR) :: zmq_socket_push
logical :: done
double precision,allocatable :: dress_detail(:)
integer :: ind
double precision,allocatable :: delta_ij_loc(:,:,:)
double precision :: div(N_states)
integer :: h,p,n,i_state
2017-12-15 16:21:04 +01:00
logical :: ok
2018-04-04 11:32:27 +02:00
integer, allocatable :: int_buf(:)
double precision, allocatable :: double_buf(:)
integer(bit_kind), allocatable :: det_buf(:,:,:)
integer :: N_buf(3)
2018-04-27 12:41:39 +02:00
logical :: last
task(:) = CHAR(0)
2018-04-04 11:32:27 +02:00
allocate(int_buf(N_dress_int_buffer))
allocate(double_buf(N_dress_double_buffer))
allocate(det_buf(N_int, 2, N_dress_det_buffer))
allocate(delta_ij_loc(N_states,N_det,2))
2017-12-15 16:21:04 +01:00
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
zmq_socket_push = new_zmq_push_socket(thread)
call connect_to_taskserver(zmq_to_qp_run_socket,worker_id,thread)
if(worker_id == -1) then
print *, "WORKER -1"
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
call end_zmq_push_socket(zmq_socket_push,thread)
return
end if
do i=1,N_states
2018-03-05 17:04:26 +01:00
div(i) = psi_coef(dressed_column_idx(i), i)
end do
2017-12-15 16:21:04 +01:00
do
call get_task_from_taskserver(zmq_to_qp_run_socket,worker_id, task_id, task)
if(task_id /= 0) then
2018-04-27 12:41:39 +02:00
task = trim(task)//' 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0'
i_generator = 0
2017-12-15 16:21:04 +01:00
read (task,*) subset, i_generator
2018-04-27 12:41:39 +02:00
if(i_generator(size(i_generator)) /= 0) stop "i_generator buffer too small"
2017-12-15 16:21:04 +01:00
delta_ij_loc = 0d0
2018-04-27 12:41:39 +02:00
i=1
do while(i_generator(i) /= 0)
call generator_start(i_generator(i), iproc)
call alpha_callback(delta_ij_loc, i_generator(i), subset, iproc)
call generator_done(i_generator(i), int_buf, double_buf, det_buf, N_buf, iproc)
last = (i_generator(i+1) == 0)
call push_dress_results(zmq_socket_push, i_generator(i), last, delta_ij_loc, int_buf, double_buf, det_buf, N_buf, task_id)
i += 1
end do
2017-12-15 16:21:04 +01:00
call task_done_to_taskserver(zmq_to_qp_run_socket,worker_id,task_id)
else
exit
end if
end do
call disconnect_from_taskserver(zmq_to_qp_run_socket,zmq_socket_push,worker_id)
call end_zmq_to_qp_run_socket(zmq_to_qp_run_socket)
call end_zmq_push_socket(zmq_socket_push,thread)
end subroutine
2018-04-04 11:32:27 +02:00
! BEGIN_PROVIDER [ integer, dress_int_buffer, (N_dress_int_buffer) ]
!&BEGIN_PROVIDER [ double precision, dress_double_buffer, (N_dress_double_buffer) ]
!&BEGIN_PROVIDER [ integer(bit_kind), dress_det_buffer, (N_int, 2, N_dress_det_buffer) ]
! implicit none
!
! dress_int_buffer = 0
! dress_double_buffer = 0d0
! dress_det_buffer = 0_bit_kind
!END_PROVIDER
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
!subroutine pull_dress_results(zmq_socket_pull, ind, delta_loc, int_buf, double_buf, det_buf, N_buf, task_id, felem)
2018-04-27 12:41:39 +02:00
subroutine push_dress_results(zmq_socket_push, ind, last, delta_loc, int_buf, double_buf, det_buf, N_bufi, task_id)
2017-12-15 16:21:04 +01:00
use f77_zmq
implicit none
integer(ZMQ_PTR), intent(in) :: zmq_socket_push
2018-04-29 17:09:46 +02:00
double precision, intent(inout) :: delta_loc(N_states, N_det, 2)
2018-04-04 11:32:27 +02:00
double precision, intent(in) :: double_buf(*)
2018-04-27 12:41:39 +02:00
logical, intent(in) :: last
2018-04-04 11:32:27 +02:00
integer, intent(in) :: int_buf(*)
integer(bit_kind), intent(in) :: det_buf(N_int, 2, *)
2018-04-27 12:41:39 +02:00
integer, intent(in) :: N_bufi(3)
integer :: N_buf(3)
2017-12-15 16:21:04 +01:00
integer, intent(in) :: ind, task_id
2018-04-29 17:09:46 +02:00
integer :: rc, i, j
double precision :: tmp(N_states,2)
integer, allocatable :: sparse(:)
integer :: sparsei
double precision :: contrib(N_states)
contrib = 0d0
allocate(sparse(N_det))
2017-12-15 16:21:04 +01:00
2018-03-30 18:16:00 +02:00
2018-04-27 12:41:39 +02:00
rc = f77_zmq_send( zmq_socket_push, ind, 4, ZMQ_SNDMORE)
if(rc /= 4) stop "push"
2018-04-27 12:41:39 +02:00
rc = f77_zmq_send( zmq_socket_push, last, 1, ZMQ_SNDMORE)
if(rc /= 1) stop "push"
2017-12-15 16:21:04 +01:00
2018-04-27 12:41:39 +02:00
if(last) then
2018-04-29 17:09:46 +02:00
sparsei = 0
do i=1,N_det
do j=1,N_states
if(delta_loc(j,i,1) /= 0d0 .or. delta_loc(j,i,2) /= 0d0) then
sparsei += 1
sparse(sparsei) = i
delta_loc(:,sparsei,:) = delta_loc(:,i,:)
contrib(:) += delta_loc(:,sparsei, 1) * psi_coef(i, :)
end if
end do
end do
rc = f77_zmq_send( zmq_socket_push, sparsei, 4, ZMQ_SNDMORE)
2018-04-27 12:41:39 +02:00
if(rc /= 4) stop "push"
2018-04-29 17:09:46 +02:00
if(sparsei /= 0) then
rc = f77_zmq_send( zmq_socket_push, contrib, 8*N_states, ZMQ_SNDMORE)
if(rc /= 8*N_states) stop "push"
rc = f77_zmq_send( zmq_socket_push, sparse, 4*sparsei, ZMQ_SNDMORE)
if(rc /= 4*sparsei) stop "push"
rc = f77_zmq_send( zmq_socket_push, delta_loc(1,1,1), 8*N_states*sparsei, ZMQ_SNDMORE)
if(rc /= 8*N_states*sparsei) stop "push"
rc = f77_zmq_send( zmq_socket_push, delta_loc(1,1,2), 8*N_states*sparsei, ZMQ_SNDMORE)
if(rc /= 8*N_states*sparsei) stop "push"
do i=sparsei,1
tmp(:,:) = delta_loc(:,i,:)
delta_loc(:,i,:) = 0d0
delta_loc(:,sparse(i),:) = tmp(:,:)
end do
end if
2018-04-27 12:41:39 +02:00
2018-04-29 17:09:46 +02:00
2018-04-27 12:41:39 +02:00
else
2018-04-29 17:09:46 +02:00
rc = f77_zmq_send( zmq_socket_push, 0, 4, ZMQ_SNDMORE)
2018-04-27 12:41:39 +02:00
if(rc /= 4) stop "push"
2018-04-29 17:09:46 +02:00
!rc = f77_zmq_send( zmq_socket_push, vast_emptiness, 8*N_states, ZMQ_SNDMORE)
!if(rc /= 8*N_states) stop "push"
2018-04-27 12:41:39 +02:00
2018-04-29 17:09:46 +02:00
!rc = f77_zmq_send( zmq_socket_push, vast_emptiness, 8*N_states, ZMQ_SNDMORE)
!if(rc /= 8*N_states) stop "push"
2018-04-27 12:41:39 +02:00
end if
2018-03-30 18:16:00 +02:00
2018-04-27 12:41:39 +02:00
N_buf = N_bufi
2018-04-29 17:09:46 +02:00
N_buf = (/0, 1, 0/)
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
rc = f77_zmq_send( zmq_socket_push, N_buf, 4*3, ZMQ_SNDMORE)
if(rc /= 4*3) stop "push5"
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
if(N_buf(1) > N_dress_int_buffer) stop "run_dress_slave N_buf bad size?"
if(N_buf(2) > N_dress_double_buffer) stop "run_dress_slave N_buf bad size?"
if(N_buf(3) > N_dress_det_buffer) stop "run_dress_slave N_buf bad size?"
2018-03-30 18:16:00 +02:00
2018-04-27 12:41:39 +02:00
2018-04-04 11:32:27 +02:00
if(N_buf(1) > 0) then
rc = f77_zmq_send( zmq_socket_push, int_buf, 4*N_buf(1), ZMQ_SNDMORE)
if(rc /= 4*N_buf(1)) stop "push6"
end if
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
if(N_buf(2) > 0) then
rc = f77_zmq_send( zmq_socket_push, double_buf, 8*N_buf(2), ZMQ_SNDMORE)
if(rc /= 8*N_buf(2)) stop "push8"
end if
if(N_buf(3) > 0) then
rc = f77_zmq_send( zmq_socket_push, det_buf, 2*N_int*bit_kind*N_buf(3), ZMQ_SNDMORE)
if(rc /= 2*N_int*bit_kind*N_buf(3)) stop "push10"
end if
2018-03-30 18:16:00 +02:00
2017-12-15 16:21:04 +01:00
rc = f77_zmq_send( zmq_socket_push, task_id, 4, 0)
2018-04-04 11:32:27 +02:00
if(rc /= 4) stop "push11"
2017-12-15 16:21:04 +01:00
! Activate is zmq_socket_push is a REQ
IRP_IF ZMQ_PUSH
IRP_ELSE
character*(2) :: ok
rc = f77_zmq_recv( zmq_socket_push, ok, 2, 0)
IRP_ENDIF
end subroutine
2018-04-29 17:09:46 +02:00
subroutine pull_dress_results(zmq_socket_pull, ind, last, delta_loc, int_buf, double_buf, det_buf, N_buf, task_id, sparse, contrib)
2017-12-15 16:21:04 +01:00
use f77_zmq
implicit none
integer(ZMQ_PTR), intent(in) :: zmq_socket_pull
2018-04-27 12:41:39 +02:00
logical, intent(out) :: last
double precision, intent(inout) :: delta_loc(N_states, N_det, 2)
2018-04-29 17:09:46 +02:00
double precision, intent(out) :: double_buf(*), contrib(N_states)
2018-03-30 18:16:00 +02:00
integer, intent(out) :: int_buf(*)
integer(bit_kind), intent(out) :: det_buf(N_int, 2, *)
2018-04-29 17:09:46 +02:00
integer, intent(out) :: sparse(0:N_det)
2017-12-15 16:21:04 +01:00
integer, intent(out) :: ind
integer, intent(out) :: task_id
2018-04-29 17:09:46 +02:00
integer :: rc, i, sparsen
2018-03-30 18:16:00 +02:00
integer, intent(out) :: N_buf(3)
2017-12-15 16:21:04 +01:00
2018-04-29 17:09:46 +02:00
2017-12-15 16:21:04 +01:00
rc = f77_zmq_recv( zmq_socket_pull, ind, 4, 0)
2018-04-04 11:32:27 +02:00
if(rc /= 4) stop "pulla"
2018-04-27 12:41:39 +02:00
rc = f77_zmq_recv( zmq_socket_pull, last, 1, 0)
if(rc /= 1) stop "pulla"
2017-12-15 16:21:04 +01:00
2018-04-29 17:09:46 +02:00
rc = f77_zmq_recv( zmq_socket_pull, sparse(0), 4, 0)
2018-04-04 11:32:27 +02:00
if(rc /= 4) stop "pullb"
2018-04-29 17:09:46 +02:00
if(sparse(0) /= 0) then
rc = f77_zmq_recv( zmq_socket_pull, contrib, 8*N_states, 0)
if(rc /= 8*N_states) stop "pullc"
2018-04-29 17:09:46 +02:00
rc = f77_zmq_recv( zmq_socket_pull, sparse(1), 4*sparse(0), 0)
if(rc /= 4*sparse(0)) stop "pullc"
2018-04-29 17:09:46 +02:00
rc = f77_zmq_recv( zmq_socket_pull, delta_loc(1,1,1), N_states*8*sparse(0), 0)
if(rc /= 8*N_states*sparse(0)) stop "pullc"
rc = f77_zmq_recv( zmq_socket_pull, delta_loc(1,1,2), N_states*8*sparse(0), 0)
if(rc /= 8*N_states*sparse(0)) stop "pulld"
else
contrib = 0d0
end if
2017-12-15 16:21:04 +01:00
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
rc = f77_zmq_recv( zmq_socket_pull, N_buf, 4*3, 0)
if(rc /= 4*3) stop "pull"
2018-03-30 18:16:00 +02:00
if(N_buf(1) > N_dress_int_buffer) stop "run_dress_slave N_buf bad size?"
if(N_buf(2) > N_dress_double_buffer) stop "run_dress_slave N_buf bad size?"
2018-04-04 11:32:27 +02:00
if(N_buf(3) > N_dress_det_buffer) stop "run_dress_slave N_buf bad size?"
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
if(N_buf(1) > 0) then
rc = f77_zmq_recv( zmq_socket_pull, int_buf, 4*N_buf(1), 0)
if(rc /= 4*N_buf(1)) stop "pull1"
end if
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
if(N_buf(2) > 0) then
rc = f77_zmq_recv( zmq_socket_pull, double_buf, 8*N_buf(2), 0)
if(rc /= 8*N_buf(2)) stop "pull2"
end if
2018-03-30 18:16:00 +02:00
2018-04-04 11:32:27 +02:00
if(N_buf(3) > 0) then
rc = f77_zmq_recv( zmq_socket_pull, det_buf, 2*N_int*bit_kind*N_buf(3), 0)
if(rc /= 2*N_int*bit_kind*N_buf(3)) stop "pull3"
end if
2018-03-30 18:16:00 +02:00
2017-12-15 16:21:04 +01:00
rc = f77_zmq_recv( zmq_socket_pull, task_id, 4, 0)
2018-04-04 11:32:27 +02:00
if(rc /= 4) stop "pull4"
2017-12-15 16:21:04 +01:00
! Activate is zmq_socket_pull is a REP
IRP_IF ZMQ_PUSH
IRP_ELSE
rc = f77_zmq_send( zmq_socket_pull, 'ok', 2, 0)
IRP_ENDIF
end subroutine