GuutBoy / awesome-mpc

A curated list of multi party computation resources and links.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

awesome-mpc Awesome

The list format was inspired from awesome list and after a fruitful lunch discussion at TPMPC. It is designed to have a central place where everyone can find open-source software designed for MPC as well as introductory material to this topic.

Moreover, the list is given alphabetically and divided into categories of libraries which are actively maintained or recently developed.

Please feel free to do a pull request with any MPC software or resource you know and it is not on the list. The current classification might not be most suitable one and I am open to any suggestions.

Contents

Theory

Books

Courses

  • FHE-MPC Advanced Grad Course - `informal grad course' in FHE and MPC.
  • Secure Computation - Secure Computation course offered by Indian Institute of Science covering secret sharing schemes, oblivious transfer to impossiblity results and zero-knowledge proofs.
  • Secure Multi-Party Computation at Scale - Boston University course that covers mathematical and algorithmic foundations of MPC, with an additional focus on deployment of state-of-the-art MPC technologies.

Tutorials

Misc

  • ePrint papers - Auto-updated list of secure computation papers.

Software

Here I tried to reference the most recent article found on specific software since enumerating all changes including the original paper is too cumbersome.

Frameworks

  • ABY - 2PC with secret sharing and garbled circuits; secure against semi-honest adversaries | NDSS'15.
  • batchDualEx - 2PC with garbled circuits; secure against malicious adversaries | eprint: 2016/632.
  • Duplo - 2PC with garbled circuits; secure against malicious adversaries.
  • Fresco - MPC supporting BGW or SPDZ protocols; secure against semi-honest or malicious adversaries | Practice'15.
  • Obliv-C - 2PC with garbled circuits; secure against semi-honest adversaries | eprint: 2015/1153.
  • Sharemind - 2PC or 3PC with secret sharing; secure against semi-honest adversaries | Cyber'13.
  • SPDZ - General MPC with secret sharing; secure against malicious adversaries | eprint: 2016/505.
  • TinyLEGO - 2PC with garbled circuits; secure against malicious adversaries | eprint: 2015/309.

Primitives

  • APRICOT - OT Extension secure against malicious adversaries | 2015/546.
  • libOTe - Library with various OT Extensions.
  • OT Extension - OT Extension secure against malicious adversaries | 2015/061.
  • SCAPI - Various secure computation API's carefully documented with a clean code design in mind | 2012/629.
  • SplitCommit - Additively homomorphic commitment scheme | 2015/694.
  • TSS - A pure-Rust implementation of various threshold secret sharing schemes.

Protocols

Tools

Contribute

Contributions welcome! Read the contribution guidelines first.

License

CC0

To the extent possible under law, Dragoș Rotaru has waived all copyright and related or neighboring rights to this work.

About

A curated list of multi party computation resources and links.