Skip to main content

Bindings to ApproxMC, an approximate model counter

Project description

pyapproxmc: bindings to the ApproxMC model counter

This directory provides Python bindings to ApproxMC on the C++ level, i.e. when importing pyapproxmc, the ApproxMC counter becomes part of the Python process itself.

Installing

pip install pyapproxmc

Compiling

If you don't want to use the pip package, you can compile it:

apt-get install python-dev
cd python
git clone https://github.com/msoos/cryptominisat
git clone https://github.com/meelgroup/arjun
cd ..
python -m build

You will then find the files under "dist/".

Usage

import pyapproxmc
c = pyapproxmc.Counter()
c.add_clause([1,2,3])
c.add_clause([3,20])
count = c.count()
print("Approximate count is: %d*2**%d" % (count[0], count[1]))

The above will print that Approximate count is: 88*2**13. Since the largest variable in the clauses was 20, the system contained 220 (i.e. 1048576) potential models. However, some of these models were prohibited by the two clauses, and so only approximately 88*213 (i.e. 720896) models remained.

If you want to count over a projection set, you need to call count(projection_set), for example:

import pyapproxmc
c = pyapproxmc.Counter()
c.add_clause([1,2,3])
c.add_clause([3,20])
count = c.count(range(1,10))
print("Approximate count is: %d*2**%d" % (count[0], count[1]))

This now prints Approximate count is: 56*2**3, which corresponds to the approximate count of models, projected over variables 1..10.

Counter Object

You can give the following arguments to Counter:

  • seed -- sets the random seed
  • verbosity -- sets the verbosity of the system (default = 0)
  • epsilon -- Tolerance parameter, i.e. sets how approximate the returned count is. Default = 0.8
  • delta -- Confidence parameter, i.e. sets how probabilistically correct the returned count is. Default = 0.20

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyapproxmc-4.1.24.tar.gz (457.5 kB view hashes)

Uploaded Source

Built Distributions

pyapproxmc-4.1.24-pp310-pypy310_pp73-win_amd64.whl (472.1 kB view hashes)

Uploaded PyPy Windows x86-64

pyapproxmc-4.1.24-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (736.6 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-pp310-pypy310_pp73-macosx_10_9_x86_64.whl (709.6 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

pyapproxmc-4.1.24-pp39-pypy39_pp73-win_amd64.whl (472.1 kB view hashes)

Uploaded PyPy Windows x86-64

pyapproxmc-4.1.24-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (736.6 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-pp39-pypy39_pp73-macosx_10_9_x86_64.whl (709.6 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

pyapproxmc-4.1.24-pp38-pypy38_pp73-win_amd64.whl (472.0 kB view hashes)

Uploaded PyPy Windows x86-64

pyapproxmc-4.1.24-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (736.6 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (709.6 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

pyapproxmc-4.1.24-pp37-pypy37_pp73-win_amd64.whl (472.0 kB view hashes)

Uploaded PyPy Windows x86-64

pyapproxmc-4.1.24-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (752.7 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-pp37-pypy37_pp73-macosx_10_9_x86_64.whl (709.6 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

pyapproxmc-4.1.24-cp312-cp312-win_amd64.whl (472.0 kB view hashes)

Uploaded CPython 3.12 Windows x86-64

pyapproxmc-4.1.24-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.7 MB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-cp312-cp312-macosx_10_9_x86_64.whl (794.3 kB view hashes)

Uploaded CPython 3.12 macOS 10.9+ x86-64

pyapproxmc-4.1.24-cp311-cp311-win_amd64.whl (471.9 kB view hashes)

Uploaded CPython 3.11 Windows x86-64

pyapproxmc-4.1.24-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.7 MB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-cp311-cp311-macosx_10_9_x86_64.whl (794.3 kB view hashes)

Uploaded CPython 3.11 macOS 10.9+ x86-64

pyapproxmc-4.1.24-cp310-cp310-win_amd64.whl (471.9 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

pyapproxmc-4.1.24-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.7 MB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-cp310-cp310-macosx_10_9_x86_64.whl (794.3 kB view hashes)

Uploaded CPython 3.10 macOS 10.9+ x86-64

pyapproxmc-4.1.24-cp39-cp39-win_amd64.whl (471.9 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

pyapproxmc-4.1.24-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.7 MB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-cp39-cp39-macosx_10_9_x86_64.whl (794.2 kB view hashes)

Uploaded CPython 3.9 macOS 10.9+ x86-64

pyapproxmc-4.1.24-cp38-cp38-win_amd64.whl (471.9 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

pyapproxmc-4.1.24-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.7 MB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-cp38-cp38-macosx_10_9_x86_64.whl (794.2 kB view hashes)

Uploaded CPython 3.8 macOS 10.9+ x86-64

pyapproxmc-4.1.24-cp37-cp37m-win_amd64.whl (472.0 kB view hashes)

Uploaded CPython 3.7m Windows x86-64

pyapproxmc-4.1.24-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (10.7 MB view hashes)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

pyapproxmc-4.1.24-cp37-cp37m-macosx_10_9_x86_64.whl (794.2 kB view hashes)

Uploaded CPython 3.7m macOS 10.9+ x86-64

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page