10
0
mirror of https://github.com/LCPQ/quantum_package synced 2024-06-26 07:02:14 +02:00
quantum_package/src/Integrals_Bielec/ao_bielec_integrals_in_map_slave.irp.f

121 lines
3.5 KiB
Fortran
Raw Normal View History

2015-12-07 22:03:33 +01:00
subroutine ao_bielec_integrals_in_map_slave_tcp
implicit none
BEGIN_DOC
! Computes a buffer of integrals
END_DOC
call ao_bielec_integrals_in_map_slave(0)
end
subroutine ao_bielec_integrals_in_map_slave_inproc
implicit none
BEGIN_DOC
! Computes a buffer of integrals
END_DOC
call ao_bielec_integrals_in_map_slave(1)
end
subroutine ao_bielec_integrals_in_map_slave(thread)
2015-12-01 16:45:41 +01:00
use map_module
use f77_zmq
implicit none
BEGIN_DOC
! Computes a buffer of integrals
END_DOC
2015-12-07 22:03:33 +01:00
integer, intent(in) :: thread
2015-12-01 16:45:41 +01:00
integer :: j,l,n_integrals
integer :: rc
real(integral_kind), allocatable :: buffer_value(:)
integer(key_kind), allocatable :: buffer_i(:)
2015-12-07 22:03:33 +01:00
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
zmq_to_qp_run_socket = new_zmq_to_qp_run_socket()
integer(ZMQ_PTR) :: zmq_socket_push
2015-12-09 23:20:34 +01:00
! zmq_socket_push = f77_zmq_socket(zmq_context, ZMQ_PUSH)
zmq_socket_push = f77_zmq_socket(zmq_context, ZMQ_REQ )
2015-12-07 22:03:33 +01:00
if (thread == 1) then
rc = f77_zmq_connect(zmq_socket_push, trim(zmq_socket_pull_inproc_address))
else
rc = f77_zmq_connect(zmq_socket_push, trim(zmq_socket_push_tcp_address))
2015-12-01 16:45:41 +01:00
endif
if (rc /= 0) then
2015-12-07 22:03:33 +01:00
stop 'Unable to connect zmq_socket_push_tcp'
2015-12-01 16:45:41 +01:00
endif
2015-12-07 22:03:33 +01:00
allocate ( buffer_i(ao_num*ao_num), buffer_value(ao_num*ao_num) )
2015-12-01 16:45:41 +01:00
2015-12-07 22:03:33 +01:00
call connect_to_taskserver(zmq_to_qp_run_socket,worker_id,thread)
2015-12-01 16:45:41 +01:00
2015-12-07 22:03:33 +01:00
do
call get_task_from_taskserver(zmq_to_qp_run_socket,worker_id, task_id, task)
if (task_id == 0) then
exit
endif
read(task,*) j, l
call compute_ao_integrals_jl(j,l,n_integrals,buffer_i,buffer_value)
rc = f77_zmq_send( zmq_socket_push, n_integrals, 4, ZMQ_SNDMORE)
rc = f77_zmq_send( zmq_socket_push, buffer_i, key_kind*n_integrals, ZMQ_SNDMORE)
rc = f77_zmq_send( zmq_socket_push, buffer_value, integral_kind*n_integrals, 0)
call task_done_to_taskserver(zmq_to_qp_run_socket,worker_id,task_id)
2015-12-09 23:20:34 +01:00
character*(2) :: ok
rc = f77_zmq_recv( zmq_socket_push, ok, 2, 0)
2015-12-01 16:45:41 +01:00
enddo
deallocate( buffer_i, buffer_value )
2015-12-07 22:03:33 +01:00
integer :: finished
call disconnect_from_taskserver(zmq_to_qp_run_socket,worker_id,finished)
if (finished /= 0) then
rc = f77_zmq_send( zmq_socket_push, -1, 4, 0)
2015-12-09 23:20:34 +01:00
rc = f77_zmq_recv( zmq_socket_push, ok, 2, ZMQ_NOBLOCK)
2015-12-07 22:03:33 +01:00
endif
rc = f77_zmq_disconnect(zmq_socket_push,trim(zmq_socket_push_tcp_address))
rc = f77_zmq_close(zmq_socket_push)
2015-12-01 16:45:41 +01:00
end
subroutine ao_bielec_integrals_in_map_collector
use map_module
use f77_zmq
implicit none
BEGIN_DOC
! Collects results from the AO integral calculation
END_DOC
integer :: j,l,n_integrals
integer :: rc
real(integral_kind), allocatable :: buffer_value(:)
integer(key_kind), allocatable :: buffer_i(:)
allocate ( buffer_i(ao_num*ao_num), buffer_value(ao_num*ao_num) )
n_integrals = 0
do while (n_integrals >= 0)
2015-12-07 22:03:33 +01:00
rc = f77_zmq_recv( zmq_socket_pull, n_integrals, 4, 0)
if (n_integrals >= 0) then
rc = f77_zmq_recv( zmq_socket_pull, buffer_i, key_kind*n_integrals, 0)
rc = f77_zmq_recv( zmq_socket_pull, buffer_value, integral_kind*n_integrals, 0)
2015-12-09 23:20:34 +01:00
rc = f77_zmq_send( zmq_socket_pull, 'ok', 2, 0)
2015-12-01 16:45:41 +01:00
call insert_into_ao_integrals_map(n_integrals,buffer_i,buffer_value)
2015-12-09 23:20:34 +01:00
else
rc = f77_zmq_send( zmq_socket_pull, 'ok', 2, 0)
2015-12-01 16:45:41 +01:00
endif
enddo
deallocate( buffer_i, buffer_value )
2015-12-07 22:03:33 +01:00
2015-12-01 16:45:41 +01:00
end