Python Z3 и concurrent.futures - PullRequest
       10

Python Z3 и concurrent.futures

0 голосов
/ 19 сентября 2018

Я хочу решить ряд параллельных задач, после чего добавляется дополнительная информация для решения новой проблемы.

Ниже приведен пример структуры программы, используемой для решения проблемы:

from z3 import *
import concurrent.futures


# solver test function
def add(a, b, solver, index):
    solver.append(a > b)
    assert solver.check()
    model = solver.model()
    return {
        'solver': solver,
        'av': model[a],
        'a': a,
        'b': b,
        'bv': model[b],
        'index': index
    }


with concurrent.futures.ThreadPoolExecutor(max_workers=5) as executor:
    # start solving the problems
    to_compute = []
    for i in range(3):
        sol = z3.Solver()
        to_compute.append(executor.submit(
            add,
            Int('a{}'.format(i)),
            Int('b{}'.format(i)),
            sol,
            i
        ))
    # wait for the solution to the computations
    next_to_solve = []
    for result_futures in concurrent.futures.as_completed(to_compute):
        results = result_futures.result()
        print(results)
        sol = results['solver']
        sol.append(results['a'] > results['av'])
        next_to_solve.append(
            executor.submit(
                add,
                results['a'],
                results['b'],
                sol,
                results['index']
            )
        )

Результаты отличаются при каждом запуске программы, результаты включают в себя:

  • Z3Exception 'неверная команда dec_ref'
  • python, который вылетает
  • Нет ошибок

Что мне нужно сделать, чтобы сделать программу более надежной?

1 Ответ

0 голосов
/ 23 сентября 2018

Вы видели этот пример: http://github.com/Z3Prover/z3/blob/master/examples/python/parallel.py

Я не эксперт по параллельным функциям в z3py, но, похоже, вам нужно быть очень осторожным при создании переменных в том же контекстечто вы запускаете решатели. В этом файле есть несколько подсказок.

...