Задать вопрос
@AlexeyRagnar

Почему не работает LoadLibrary в функции Worker при использовании multiprocessing?

Пытаюсь оптимизировать время работы программы при помощи использовании DLL в функции mpCalcDllWorker.
DLL возвращает какой-то мусор. В однопоточном режиме DLL работает безошибочно.

Вот упрощенный пример.
def mpCalcDllWorker(nodes, queue, arrD):

    dll_fn = "***"
    lib = ctypes.cdll.LoadLibrary(dll_fn)
    print("lib:", lib)
    D = np.reshape( np.frombuffer(arrD), 1000000 )

    while True:
        job = queue.get()
        if job == None:
            break

        start = job[0]
        stop = job[1]
        lib.dll_add_ts.restype = ctypes.c_double
        ret = lib.dll_add_ts( nodes.ctypes.data_as(ctypes.c_void_p), ctypes.c_int(start), ctypes.c_int(stop) )
        print("start", start, "stop", stop, ret)
        print("nodes", nodes)
        D[start] = ret

        queue.task_done()
    queue.task_done()

def mpCalcWorker(nodes, queue, arrD):
    """ Worker process for the multiprocessing calculations
    """
    D = np.reshape( np.frombuffer(arrD), 1000000 )

    while True:
        job = queue.get()
        if job == None:
            break

        start = job[0]
        stop  = job[1]

        D[start] = sum(nodes[start:stop])

        queue.task_done()
    queue.task_done()

def mpCalcSums(arr, res, tp=0):
    # allocate shared array

    arrD = mp.RawArray(ctypes.c_double, 1000000)

    # setup jobs
    nCPU = mp.cpu_count()
    jobs = []
    for i in range(100000):
        jobs.append((i, i+10000))

    queue = mp.JoinableQueue()
    for job in jobs:
        queue.put(job)
    for i in range(nCPU):
        queue.put(None)

    # run workers
    workers = []
    for i in range(nCPU):
        if tp==0:
            worker = mp.Process(target=mpCalcWorker,    args=(arr, queue, arrD))
        if tp==1:
            worker = mp.Process(target=mpCalcDllWorker, args=(arr, queue, arrD))
        workers.append(worker)
        #worker.daemon=True  - не влияет на ошибку
        worker.start()
    queue.join()

    # make array from shared memory
    D = np.reshape(np.frombuffer(arrD), res.shape)
    return D

Возможно ли использовать функции, импортированные из DLL, в Воркерах?
Если возможно, укажите на мою ошибку.
  • Вопрос задан
  • 54 просмотра
Подписаться 1 Сложный 2 комментария
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы