[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/lschoe/mpyc/master)
[![Travis CI](https://app.travis-ci.com/lschoe/mpyc.svg)](https://app.travis-ci.com/lschoe/mpyc)
[![codecov](https://codecov.io/gh/lschoe/mpyc/branch/master/graph/badge.svg)](https://codecov.io/gh/lschoe/mpyc)
[![Read the Docs](https://readthedocs.org/projects/mpyc/badge/)](https://mpyc.readthedocs.io)
[![PyPI](https://img.shields.io/pypi/v/mpyc.svg)](https://pypi.org/project/mpyc/)
# MPyC [![MPyC logo](https://raw.githubusercontent.com/lschoe/mpyc/master/images/MPyC_Logo.svg)](https://github.com/lschoe/mpyc) Multiparty Computation in Python
MPyC supports secure *m*-party computation tolerating a dishonest minority of up to *t* passively corrupt parties,
where *m ≥ 1* and *0 ≤ t < m/2*. The underlying cryptographic protocols are based on threshold secret sharing over finite
fields (using Shamir's threshold scheme and optionally pseudorandom secret sharing).
The details of the secure computation protocols are mostly transparent due to the use of sophisticated operator overloading
combined with asynchronous evaluation of the associated protocols.
## Documentation
[Read the Docs](https://mpyc.readthedocs.io/) for `Sphinx`-based documentation, including an overview of the `demos`.\
[GitHub Pages](https://lschoe.github.io/mpyc/) for `pydoc`-based documentation.
See `demos` for Python programs and Jupyter notebooks with lots of example code. Click the "launch binder" badge above to view the entire
repository and try out the Jupyter notebooks from the `demos` directory in the cloud, without any install.
The [MPyC homepage](https://www.win.tue.nl/~berry/mpyc/) has some more info and background.
## Installation
Pure Python, no dependencies. Python 3.9+ (following [SPEC 0 — Minimum Supported Dependencies](https://scientific-python.org/specs/spec-0000/)).
Run `pip install .` in the root directory (containing file `setup.py`).\
Or, run `pip install -e .`, if you want to edit the MPyC source files.
Use `pip install numpy` to enable support for secure NumPy arrays in MPyC, along with vectorized implementations.
Use `pip install gmpy2` to run MPyC with the package [gmpy2](https://pypi.org/project/gmpy2/) for considerably better performance.
Use `pip install uvloop` (or `pip install winloop` on Windows) to replace Python's default asyncio event loop in MPyC for generally improved performance.
### Some Tips
- Try `run-all.sh` or `run-all.bat` in the `demos` directory to have a quick look at all pure Python demos.
Demos `bnnmnist.py` and `cnnmnist.py` require [NumPy](https://www.numpy.org/), demo `kmsurvival.py` requires
[pandas](https://pandas.pydata.org/), [Matplotlib](https://matplotlib.org/), and [lifelines](https://pypi.org/project/lifelines/),
and demo `ridgeregression.py` (and therefore demo `multilateration.py`) even require [Scikit-learn](https://scikit-learn.org/).\
Try `np-run-all.sh` or `np-run-all.bat` in the `demos` directory to run all Python demos employing MPyC's secure arrays.
Major speedups are achieved due to the reduced overhead of secure arrays and vectorized processing throughout the
protocols.
- To use the [Jupyter](https://jupyter.org/) notebooks `demos\*.ipynb`, you need to have Jupyter installed,
e.g., using `pip install jupyter`. An interesting feature of Jupyter is the support of top-level `await`.
For example, instead of `mpc.run(mpc.start())` you can simply use `await mpc.start()` anywhere in
a notebook cell, even outside a coroutine.\
For Python, you also get top-level `await` by running `python -m asyncio` to launch a natively async REPL.
By running `python -m mpyc` instead you even get this REPL with the MPyC runtime preloaded!
- Directory `demos\.config` contains configuration info used to run MPyC with multiple parties.
The file `gen.bat` shows how to generate fresh key material for SSL. To generate SSL key material of your own, first run
`pip install cryptography`.
Copyright © 2018-2024 Berry Schoenmakers
Raw data
{
"_id": null,
"home_page": "https://github.com/lschoe/mpyc",
"name": "mpyc",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "crypto, cryptography, multiparty computation, MPC, secret sharing, Shamir threshold scheme, pseudorandom secret sharing, PRSS",
"author": "Berry Schoenmakers",
"author_email": "berry@win.tue.nl",
"download_url": "https://files.pythonhosted.org/packages/53/a8/c8d9155afd5207548ebe9b8b2082011448bea3772ad208c9a734f37e369c/mpyc-0.10.tar.gz",
"platform": "any",
"description": "[![Binder](https://mybinder.org/badge_logo.svg)](https://mybinder.org/v2/gh/lschoe/mpyc/master)\r\n[![Travis CI](https://app.travis-ci.com/lschoe/mpyc.svg)](https://app.travis-ci.com/lschoe/mpyc)\r\n[![codecov](https://codecov.io/gh/lschoe/mpyc/branch/master/graph/badge.svg)](https://codecov.io/gh/lschoe/mpyc)\r\n[![Read the Docs](https://readthedocs.org/projects/mpyc/badge/)](https://mpyc.readthedocs.io)\r\n[![PyPI](https://img.shields.io/pypi/v/mpyc.svg)](https://pypi.org/project/mpyc/)\r\n\r\n# MPyC [![MPyC logo](https://raw.githubusercontent.com/lschoe/mpyc/master/images/MPyC_Logo.svg)](https://github.com/lschoe/mpyc) Multiparty Computation in Python\r\n\r\nMPyC supports secure *m*-party computation tolerating a dishonest minority of up to *t* passively corrupt parties,\r\nwhere *m ≥ 1* and *0 ≤ t < m/2*. The underlying cryptographic protocols are based on threshold secret sharing over finite\r\nfields (using Shamir's threshold scheme and optionally pseudorandom secret sharing).\r\n\r\nThe details of the secure computation protocols are mostly transparent due to the use of sophisticated operator overloading\r\ncombined with asynchronous evaluation of the associated protocols.\r\n\r\n## Documentation\r\n\r\n[Read the Docs](https://mpyc.readthedocs.io/) for `Sphinx`-based documentation, including an overview of the `demos`.\\\r\n[GitHub Pages](https://lschoe.github.io/mpyc/) for `pydoc`-based documentation.\r\n\r\nSee `demos` for Python programs and Jupyter notebooks with lots of example code. Click the \"launch binder\" badge above to view the entire\r\nrepository and try out the Jupyter notebooks from the `demos` directory in the cloud, without any install.\r\n\r\nThe [MPyC homepage](https://www.win.tue.nl/~berry/mpyc/) has some more info and background.\r\n\r\n## Installation\r\n\r\nPure Python, no dependencies. Python 3.9+ (following [SPEC 0 \u00e2\u20ac\u201d Minimum Supported Dependencies](https://scientific-python.org/specs/spec-0000/)).\r\n\r\nRun `pip install .` in the root directory (containing file `setup.py`).\\\r\nOr, run `pip install -e .`, if you want to edit the MPyC source files.\r\n\r\nUse `pip install numpy` to enable support for secure NumPy arrays in MPyC, along with vectorized implementations.\r\n\r\nUse `pip install gmpy2` to run MPyC with the package [gmpy2](https://pypi.org/project/gmpy2/) for considerably better performance.\r\n\r\nUse `pip install uvloop` (or `pip install winloop` on Windows) to replace Python's default asyncio event loop in MPyC for generally improved performance.\r\n\r\n### Some Tips\r\n\r\n- Try `run-all.sh` or `run-all.bat` in the `demos` directory to have a quick look at all pure Python demos.\r\nDemos `bnnmnist.py` and `cnnmnist.py` require [NumPy](https://www.numpy.org/), demo `kmsurvival.py` requires\r\n[pandas](https://pandas.pydata.org/), [Matplotlib](https://matplotlib.org/), and [lifelines](https://pypi.org/project/lifelines/),\r\nand demo `ridgeregression.py` (and therefore demo `multilateration.py`) even require [Scikit-learn](https://scikit-learn.org/).\\\r\nTry `np-run-all.sh` or `np-run-all.bat` in the `demos` directory to run all Python demos employing MPyC's secure arrays.\r\nMajor speedups are achieved due to the reduced overhead of secure arrays and vectorized processing throughout the\r\nprotocols.\r\n\r\n- To use the [Jupyter](https://jupyter.org/) notebooks `demos\\*.ipynb`, you need to have Jupyter installed,\r\ne.g., using `pip install jupyter`. An interesting feature of Jupyter is the support of top-level `await`.\r\nFor example, instead of `mpc.run(mpc.start())` you can simply use `await mpc.start()` anywhere in\r\na notebook cell, even outside a coroutine.\\\r\nFor Python, you also get top-level `await` by running `python -m asyncio` to launch a natively async REPL.\r\nBy running `python -m mpyc` instead you even get this REPL with the MPyC runtime preloaded!\r\n\r\n- Directory `demos\\.config` contains configuration info used to run MPyC with multiple parties.\r\nThe file `gen.bat` shows how to generate fresh key material for SSL. To generate SSL key material of your own, first run\r\n`pip install cryptography`.\r\n\r\nCopyright © 2018-2024 Berry Schoenmakers\r\n",
"bugtrack_url": null,
"license": "MIT License",
"summary": "MPyC for Multiparty Computation in Python",
"version": "0.10",
"project_urls": {
"Homepage": "https://github.com/lschoe/mpyc"
},
"split_keywords": [
"crypto",
" cryptography",
" multiparty computation",
" mpc",
" secret sharing",
" shamir threshold scheme",
" pseudorandom secret sharing",
" prss"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "65255b0e7ca2f3b449c86dc2a7d275363f40b18cc7bf1aa577ea996cf60e723d",
"md5": "cd9f1d6e19486104ce648be9f3c4b5d5",
"sha256": "321cb44b7f4355c19a97e6f791d1d6128c0316906fc3bfb07a862e0c04940bf8"
},
"downloads": -1,
"filename": "mpyc-0.10-py3-none-any.whl",
"has_sig": false,
"md5_digest": "cd9f1d6e19486104ce648be9f3c4b5d5",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.9",
"size": 112196,
"upload_time": "2024-04-16T15:28:42",
"upload_time_iso_8601": "2024-04-16T15:28:42.745900Z",
"url": "https://files.pythonhosted.org/packages/65/25/5b0e7ca2f3b449c86dc2a7d275363f40b18cc7bf1aa577ea996cf60e723d/mpyc-0.10-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "53a8c8d9155afd5207548ebe9b8b2082011448bea3772ad208c9a734f37e369c",
"md5": "d97395c9123c256f1b9f36a522e1b695",
"sha256": "c42d4d062424e840aa1ab2a938955aa7e36ed0eb6d8b82f0ccf98f9288fea5c3"
},
"downloads": -1,
"filename": "mpyc-0.10.tar.gz",
"has_sig": false,
"md5_digest": "d97395c9123c256f1b9f36a522e1b695",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 132513,
"upload_time": "2024-04-16T15:28:44",
"upload_time_iso_8601": "2024-04-16T15:28:44.814859Z",
"url": "https://files.pythonhosted.org/packages/53/a8/c8d9155afd5207548ebe9b8b2082011448bea3772ad208c9a734f37e369c/mpyc-0.10.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-04-16 15:28:44",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "lschoe",
"github_project": "mpyc",
"travis_ci": true,
"coveralls": false,
"github_actions": false,
"lcname": "mpyc"
}