Skip to main content

A circuit toolkit mainly for cryptographic usage.

Project description

circkit

circkit is a small framework for defining, constructing and manipulating computational circuits. It aims to be very generic. circkit supports both low-level circuits such as bit-based operations, word-based operations, arithmetic circuits over a ring and high-level circuits made up by gates which are customized non-primitive functions.

Installation

For arithmetic circuits working on finite fields, it needs to install Sagemath. For circuits working on decimal numbers, integers, boolean and bitwise, it is not necessary to install Sagemath.

Circuits with Sagemath

  1. Install Sagemath.

  2. Install circkit in Sagemath:

  • via PyPI:
sage -pip install circkit
  • or via setup.py
sage -pip install .
  1. Run your script with Sagemath:
sage -python script.py

Or you can open a notebook with Sagemath and build your circuit with the circkit framework:

sage -n

Circuits without Sagemath

  1. Install circuit:
  • via PyPI:
pip3 install circkit
  • or via setup.py
pip3 install .
  1. Run your python script, for example:
python3 script.py

Using a virtual environment

We can use a virtual enviroment to run both circuits with and without Sagemath.

  1. Create a virtual environment of Sagemath:
sage -python -m venv --system-site-packages .venv

Then, go to the virtual enviroment:

source .venv/bin/activate
  1. Install circkit in the virtual environment.
  • via PyPI:
pip install circkit
  • or via setup.py
pip install .
  1. Run your script on the virtual enviroment, for example:
python script.py

Or you can open a python notebook in this virtual enviroment and build your circuit. Again, both circuits working with and without Sagemath can be run on this virtual environment.

Tests

You can run the tests in the tests folder:

pytest tests

NOTE: you should run the tests in the virtual environment (see installation) because the tests consists of both circuits with Sagemath and circuits without Sagemath. Otherwise, it will fail on the tests requiring Sagemath.

You can run a specific test, for example:

pytest tests/test_simon_cipher.py

Documentation

See circkit.readthedocs.io for the documentations. You can also open the file docs/_build/html/index.html file on your browser.

Tutorials

Some jupyter notebooks are provided to help you play with the circkit framework:

Advanced examples

Some advance examples are also provided. These examples highlight the applications of the circkit framework in cryptography.

Authors

CryptoExperts Team

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

circkit-0.1.0.tar.gz (41.0 kB view hashes)

Uploaded Source

Built Distribution

circkit-0.1.0-py3-none-any.whl (50.5 kB view hashes)

Uploaded Python 3

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