Skip to main content

Python bindings for the BN254/256 pairing-friendly curve supported by the MCl library.

Project description

Python library that serves as an API for the BN254/256 pairing-friendly curve implemented in MCl in C.

PyPI version and link.

Package Installation and Usage

The package is available on PyPI:

pip install mclbn256

The library can be imported in the usual ways:

import mclbn256  # Abstracted 'dumb' API over the scalar and point groups
from mclbn256 import mclbn256  # Extended attributes, internals, classes, test methods

Examples

This library supports concise construction of elliptic curve points (groups G1 and G2) and scalars (group Fr):

from mclbn256 import G1, G2, Fr
>>> p = G1().hash("some row")
>>> q = G2().hash("another row")
>>> p.valid()
True
>>> q.valid()
True
>>> s = Fr(6)
>>> t = Fr(857462736753)
>>> ((p * s) @ (q * t)) == (p @ (q * s * t))
True
>>> ((p * s * ~t) @ (q * t)) == (p @ (q * s))
True
>>> ((p * s) @ q) == ((p * ~t) @ (q * s * t))
True

Data structures for the relevant curve subgroups and finite fields are included as well:

>>> len(Fr().randomize().serialize())
32
>>> len(G1().randomize().serialize())
32
>>> len(G2().randomize().serialize())
64
>>> len((G1().randomize() @ G2().randomize()).serialize()) <= 384
True

The representation of BN254 points and scalars in this library is compatible with the pure-Python bn254 implementation thanks to ECp_to_G1 and the other similarly-named helpers. We may also convert points in that library’s representation to the minimal-size MCl serial format using ECp_serialize.

>>> Q = G1.random(); G1().deserialize(ECp_serialize(G1_to_ECp(Q))) == Q and Q.serialize() == ECp_serialize(G1_to_ECp(Q))
True

Please see the package oblivious (which extends this package) for more examples of how to use the BN254 curve.

Contributions

In order to contribute to the source code, open an issue or submit a pull request on the GitHub page for this library.

Versioning

Beginning with version 0.1.0, the version number format for this library and the changes to the library associated with version number increments conform with Semantic Versioning 2.0.0.

Naming Notes

BN-256 was an old name for the BarretoNaehrig(2,254) Weierstrass curve, when it was though to have close to 256 bits of security. It has since been estimated to have at least 90 bits of security (compared to symmetric ciphers) and is now more commonly refered to by BN254, after the number of bits in its prime modulus. Specifically, mclbn256 is the name of the subset of the MCl library containing the support for this curve.

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

mclbn256-1.3.5-py3-none-win_amd64.whl (1.5 MB view hashes)

Uploaded Python 3 Windows x86-64

mclbn256-1.3.5-py3-none-win32.whl (1.5 MB view hashes)

Uploaded Python 3 Windows x86

mclbn256-1.3.5-py3-none-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (21.6 MB view hashes)

Uploaded Python 3 manylinux: glibc 2.17+ x86-64

mclbn256-1.3.5-py3-none-macosx_12_0_arm64.whl (1.7 MB view hashes)

Uploaded Python 3 macOS 12.0+ ARM64

mclbn256-1.3.5-py3-none-macosx_11_0_universal2.whl (2.7 MB view hashes)

Uploaded Python 3 macOS 11.0+ universal2 (ARM64, x86-64)

mclbn256-1.3.5-py3-none-macosx_10_15_x86_64.whl (2.7 MB view hashes)

Uploaded Python 3 macOS 10.15+ 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