No project description provided
Project description
Puan DB Python Client
Install
pip install puan-db-python
A quick what-is-dis
A Python library for connecting to a puan-db instance. Puan DB is a logical reasoning database which draws conclusions from a model and finds combinations which satisfies a model while minimizing/maximizing some objective function.
There are two types of variables to keep in mind:
- Primitives. These are defined by an ID given by you, and a lower and upper bound representing which integer values this variable may take in the future. The bound is a complex number so a boolean variable
xwould be declared with the bound0+1j, or just1j, as suchmodel.set_primitive("x", 1j) - Composites. These are created using one or more other primitives or composites as a connecter between them. For instance, an OR-connector is defined as
model.set_or(["x","y","z"]).
Example
import puan_db_python
# Connect to back end
client = puan_db_python.PuanClient(
host="localhost",
port=50051,
ssl=False,
)
# Select or create a model
model = client.create(id="test", password="test")
# Set some primitive variables
model.set_primitives(["x","y","z"])
# And a composite
id = model.set_atleast(["x","y","z"], 1, alias="A")
# Same one could be set instead by
other_id = model.set_or(["x","y","z"], alias="A")
assert id == other_id
# If you forget the id but remember the alias, there's a pointer to it
forgot_id = model.id_from_alias("A")
assert (id == forgot_id) and (forgot_id == other_id)
# Now we can do some propagation to verify some values.
# For instance, if x is 1, then A should be true as well.
# Note that you must give the ID and not the alias when getting its value
model.propagate({"x": 1+1j}).get(id) == 1+1j
# Or maybe we want to find a combination that trying
# to not include x and even more not y, such that (x or y or z) must be true.
# Note that we can send in multiple "objectives" and there's one solution returned
# by each objective
solutions = model.solve(
objectives=[
{
"x": -1,
"y": -2,
}
],
assume={id: 1+1j},
solver=puan_db_python.Solver.GLPK,
)
# Modify the model and compute on it's sub system
# Sub function cuts away the top of the given id's and make them as roots
# This is a stupid example, since it will just leave the graph as is
sub_model = model.sub([id])
# ... do something
sub_model.propagate({"x": 1+1j})
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file puan_db_python-0.1.41.tar.gz.
File metadata
- Download URL: puan_db_python-0.1.41.tar.gz
- Upload date:
- Size: 13.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.9.19 Darwin/23.1.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2799610eae1464ad676399f3a9e999834226eaa6f13903525c638030009d26cf
|
|
| MD5 |
0a38761be20b3a76ef1b1ebe6dc7a7cb
|
|
| BLAKE2b-256 |
6226072709c7bb60d92138fb37e602d4c85bf3cd94049feabb1b45b3a1a5ab38
|
File details
Details for the file puan_db_python-0.1.41-py3-none-any.whl.
File metadata
- Download URL: puan_db_python-0.1.41-py3-none-any.whl
- Upload date:
- Size: 13.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.2 CPython/3.9.19 Darwin/23.1.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e70fcea0dc7e1a850f750d892b5f6f270ad8a03b2298e13adc8de0d12e33b88e
|
|
| MD5 |
256926e709b935803a97e3506163209b
|
|
| BLAKE2b-256 |
35b2f312fc076d6c0e5c216d156e12708714ed675fed481722abd41026fd458c
|