Files
z3/examples/python/parallel.py

37 lines
849 B
Python
Raw Permalink Normal View History

2018-05-19 11:13:53 +02:00
from z3 import *
from multiprocessing.pool import ThreadPool
from copy import deepcopy
pool = ThreadPool(8)
x = Int('x')
assert x.ctx == main_ctx()
def calculate(x, n, ctx):
""" Do a simple computation with a context"""
assert x.ctx == ctx
assert x.ctx != main_ctx()
2018-05-19 11:16:20 +02:00
# Parallel creation of z3 object
2018-05-19 11:13:53 +02:00
condition = And(x < 2, x > n, ctx)
2018-05-19 11:16:20 +02:00
# Parallel solving
2018-05-19 11:13:53 +02:00
solver = Solver(ctx=ctx)
solver.add(condition)
solver.check()
for i in range(100):
# Create new context for the computation
# Note that we need to do this sequentially, as parallel access to the current context or its objects
# will result in a segfault
i_context = Context()
x_i = deepcopy(x).translate(i_context)
# Kick off parallel computation
pool.apply_async(calculate, [x_i, i, i_context])
pool.close()
pool.join()