Skip to main content

Feyn is the high level Python interface to interact with an Abzu QLattice.

Project description

Feyn: AI by Abzu

Feyn is a Python library that pushes machine learning to a new level by taking strong inspiration from quantum physics. A Feyn model is based on the path integral formulation of quantum physics originally proposed by the American physicist Richard P. Feynman.

Feyn models are in many ways similar to Neural Network (or Deep Learning) models, so some of the concepts may be familiar to you already. But at it's core, the Feyn model introduces a new way to work with your data together with a revolutionary way to accumulate and transfer learnings.

But let's start with the basics.

To generate a Feyn-model you need access to a QLattice, short for Quantum Lattice. A QLattice is a high-performance quantum simulator that runs on dedicated hardware. To learn more about getting access to a QLattice, visit www.abzu.ai

The other needed component is this Python package (feyn) that runs on your computer and accumulate learnings from your data. These learnings are communicated to your QLattice over the network.

A QLattice is the heart of a Feyn model. The QLattice is divided into 2 different parts: the registers and the interactions.

The registers are what we use to interact with the QLattice. They are the input and output interface of a Feyn model. There are different register types, but the basics are continuous and categorical. The output register is always continuous. More on this later.

The interactions layer is where the learnings are stored and is what we use to extract the QGraphs.

The QGraph represents all possible graphs, from the input registers to the output register. In human words that means all possible explanations for the given output with the given inputs, suggested by the qlattice.

Getting started: Feyn in 1 min

Ok, all this sounds good! But in practice how does this work?

Let us walk through a simple classification problem, step by step.

For this quick walk-through we will pick a simple classification problem. The breast cancer dataset which is bundled with sklearn.

This will show you the core concepts in building a graph to execute predictions, that you can deploy to your application.

Connect to your QLattice

from feyn import QLattice

qlattice = QLattice(url = "<URL to your qlattice>")
qlattice

Add registers

Read the example dataset and add a register for each column in the dataset.

The registers describes your problem. Which features goes in, and which feature do you want to predict. Often the same as the columns in your dataset.

import sklearn.datasets
import pandas as pd

breast_cancer = sklearn.datasets.load_breast_cancer()

# Convert to a pandas dataframe
df = pd.DataFrame(breast_cancer.data,columns=breast_cancer.feature_names)
df['target'] = pd.Series(breast_cancer.target)
df.head()

in_registers = []

# Create an input register for each input feature
for feature in breast_cancer.feature_names:
    in_registers.append(qlattice.get_register(label=feature))

# Turn the target column into an output register
out_reg = qlattice.get_register(label='target')

Now the QLattice is prepared for your problem.

Train locally and update learnings remotely

Next, run for some epochs, where you retrieve a new QGraph, fit it to the training data, and update the QLattice with the learnings from the best graph.

The update calls will bias the QLattice from your learnings. Meaning that next time you call qlattice.get_qgraph, the new QGraph will fit your problem better.

Notice, that the QLattice lives remotely on the Abzu cluster, but it never sees your local data. The dataset stays on your premise. So, you train locally, and just transmit your learnings to the QLattice. That is the way the QLattice gets better at producing QGraphs that fits your problem.

from sklearn.model_selection import train_test_split


train, test = train_test_split(df, test_size=0.33)

for _ in range(10):
    # Get a QGraph full of graphs between your inputs and output from the remote QLattice.
    # This QGraph will be biased towards what was learned from the previous `update` calls.
    qgraph = qlattice.get_qgraph(in_registers, out_reg)

    # Now fit the local QGraph with your local data
    qgraph.fit(train, epochs=10)

    # Select the graph with lowest loss on the training dataset as the best solution.
    # You could consider other attributes as your "best" (accuracy, complexity, etc.).
    best_graph = qgraph.select(test)[0]

    # Teach the QLattice about this solution, so that it gets biased towards solutions similar to this.
    qlattice.update(best_graph)

Evaluate

Finally, evaluate the results in the test dataset. This is also how you utilize the Graph for predictions in your application.

from feyn import tools

# Use the graph to produce predictions. This graph is similar your model in other framework.
# It is the thing you can save to a file, and deploy to your application or production environment.
predictions = best_graph.predict(X_test)

# This is a classification problem, but we are using a regression model to solve it.
# There are many ways to do this. In this example we will round to nearest integer (the class).
predictions = predictions.round()

tools.plot_confusion_matrix(y_true=test["target"],
                            y_pred=predictions,
                            title="Evaluation Results")

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

feyn-1.1.0b2-cp38-cp38-manylinux2014_x86_64.whl (137.2 kB view details)

Uploaded CPython 3.8

feyn-1.1.0b2-cp38-cp38-manylinux1_x86_64.whl (137.2 kB view details)

Uploaded CPython 3.8

feyn-1.1.0b2-cp37-cp37m-manylinux2014_x86_64.whl (138.7 kB view details)

Uploaded CPython 3.7m

feyn-1.1.0b2-cp37-cp37m-manylinux1_x86_64.whl (138.7 kB view details)

Uploaded CPython 3.7m

feyn-1.1.0b2-cp36-cp36m-manylinux2014_x86_64.whl (134.1 kB view details)

Uploaded CPython 3.6m

feyn-1.1.0b2-cp36-cp36m-manylinux1_x86_64.whl (134.1 kB view details)

Uploaded CPython 3.6m

File details

Details for the file feyn-1.1.0b2-cp38-cp38-manylinux2014_x86_64.whl.

File metadata

  • Download URL: feyn-1.1.0b2-cp38-cp38-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 137.2 kB
  • Tags: CPython 3.8
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6

File hashes

Hashes for feyn-1.1.0b2-cp38-cp38-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 7002dba1cf7ccfcf0b866384c6aeb39239795bc59f8e6cf826d812b04454c13a
MD5 5b59ce37e698c7de21b5ac70363a432e
BLAKE2b-256 022be3e97df91e46be0cc1b36a14d038eff681ec2e1155a42ca3793763767723

See more details on using hashes here.

File details

Details for the file feyn-1.1.0b2-cp38-cp38-manylinux1_x86_64.whl.

File metadata

  • Download URL: feyn-1.1.0b2-cp38-cp38-manylinux1_x86_64.whl
  • Upload date:
  • Size: 137.2 kB
  • Tags: CPython 3.8
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6

File hashes

Hashes for feyn-1.1.0b2-cp38-cp38-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 d16e7be859cb2f82528cd4a1066a2a85ae1b1594ec6b0f716dfa5486fa2b1c40
MD5 d994971b9e105e967fe44fffeaa0043a
BLAKE2b-256 480f5e46b9a28517531c3ab95946d39ab9acc2e0a3b8b563435b824b637bca59

See more details on using hashes here.

File details

Details for the file feyn-1.1.0b2-cp37-cp37m-manylinux2014_x86_64.whl.

File metadata

  • Download URL: feyn-1.1.0b2-cp37-cp37m-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 138.7 kB
  • Tags: CPython 3.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6

File hashes

Hashes for feyn-1.1.0b2-cp37-cp37m-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 47bc43c20f9dce927a2f1178091e4a1ca766a39be3504e4e6bafdef97c2968fd
MD5 5f9dc03649b88d3e54515e5dd23037ae
BLAKE2b-256 b6113fe8069f2da171c5fb8b881e49cb9c1651b79cb36156172d6af98083282e

See more details on using hashes here.

File details

Details for the file feyn-1.1.0b2-cp37-cp37m-manylinux1_x86_64.whl.

File metadata

  • Download URL: feyn-1.1.0b2-cp37-cp37m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 138.7 kB
  • Tags: CPython 3.7m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6

File hashes

Hashes for feyn-1.1.0b2-cp37-cp37m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 a908191502750840eb5219fb9b93ce80484b91826b8654f8372acb1884ed9851
MD5 155d6f7cb580c74b5923c7338947a34b
BLAKE2b-256 9329b9213c39d5c0dc924f5881e8567bc62032201c2daf3999e7fa544b61f669

See more details on using hashes here.

File details

Details for the file feyn-1.1.0b2-cp36-cp36m-manylinux2014_x86_64.whl.

File metadata

  • Download URL: feyn-1.1.0b2-cp36-cp36m-manylinux2014_x86_64.whl
  • Upload date:
  • Size: 134.1 kB
  • Tags: CPython 3.6m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6

File hashes

Hashes for feyn-1.1.0b2-cp36-cp36m-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 0803af9a2a5762d3c8fe158b31d27cfef9a0265ab7d1d51705d006543ebe072a
MD5 f8ffa959667cb8f6e8797f8fc25822c4
BLAKE2b-256 2c796c6219a2254ed6f2092550810713c38f9bf045fce06a2c05c92838aea915

See more details on using hashes here.

File details

Details for the file feyn-1.1.0b2-cp36-cp36m-manylinux1_x86_64.whl.

File metadata

  • Download URL: feyn-1.1.0b2-cp36-cp36m-manylinux1_x86_64.whl
  • Upload date:
  • Size: 134.1 kB
  • Tags: CPython 3.6m
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/45.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6

File hashes

Hashes for feyn-1.1.0b2-cp36-cp36m-manylinux1_x86_64.whl
Algorithm Hash digest
SHA256 1c88614fedce10689e715dca7c9b40699e62ff83407eec5570ccb6bd7a0e3ad1
MD5 f6200535e5bfec945b691f7fe576c994
BLAKE2b-256 9b48b899e560b719366fde66b8ae703b3c25cef3f5cc398b51a1336b2e983cb8

See more details on using hashes here.

Supported by

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