Skip to content

A curated list of multi party computation resources and links.

Notifications You must be signed in to change notification settings

GuutBoy/awesome-mpc

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 

Repository files navigation

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.

Resources

Code of conduct

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published