This README is a living document and will be updated as the project progresses through its milestones.
Multilinear Polynomial Commitment Schemes (MLE PCS) are fundamental building blocks in the field of cryptography, particularly within zero-knowledge proofs. These schemes enable the commitment to a multilinear polynomial in such a way that the prover can later reveal evaluations of the polynomial at specific points without revealing the entire polynomial. Efficient and secure MLE PCS schemes are crucial for the development of scalable and practical zero-knowledge proof systems.
This repository, mle-pcs, is a research-driven project focused on the Comparison of Multilinear Polynomial Commitment Schemes. The research is supported by the Ethereum Foundation and aims to provide a comprehensive analysis of different schemes, their design philosophies, security properties, and performance metrics.
The primary objective of this project is to conduct a comprehensive comparison of various MLE PCS schemes. By implementing reference codes and analyzing their protocol designs, security parameters, and performance metrics, we aim to identify the strengths and weaknesses of each scheme.
- Reference Implementations: Python-based implementations of various MLE PCS schemes to deepen understanding.
- Interactive Tutorials: Jupyter notebooks serve as interactive playgrounds for experimenting with different schemes.
- Comprehensive Notes: Detailed research notes available in each folder, provided in both English and Chinese.
- Future Blog Posts: Planned blog posts will elaborate on the research findings and comparisons.
The repository is organized to facilitate both research and experimental exploration:
layout:
mle-pcs/
├── basefold/
│ ├── basefold-01.md
│ ├── basefold-01.zh.md
│ ├── basefold-02.md
│ ├── basefold-02.zh.md
│ └── ...
├── fri/
│ ├── BBHR18-FRI.md
│ ├── BBHR18-FRI.zh.md
│ ├── BCIKS20-proximity-gaps.md
│ ├── BCIKS20-proximity-gaps.zh.md
│ └── ...
├── fri-binius/
│ ├── binius-01.md
│ ├── binius-01.zh.md
│ ├── binius-02.md
│ ├── binius-02.zh.md
│ └── ...
├── zeromorph/
│ ├── zeromorph.md
│ ├── zeromorph.zh.md
│ ├── zeromorph_mapping_tutorial.ipynb
│ └── ...
├── src/
│ ├── Basefold.py
│ ├── Basefold.ipynb
│ ├── bcho_pcs.ipynb
│ ├── kzg10.ipynb
│ ├── zeromorph.ipynb
│ └── ... (other source files)
- basefold/: Contains research notes related to the BaseFold PCS scheme
- fri/: Focuses on the Fast Reed-Solomon Interactive Oracle Proofs of Proximity (FRI) scheme.
- fri-binius/: Explores the Binius-PCS scheme based on FRI.
- zeromorph/: Includes tutorials and notes on the Zeromorph PCS scheme.
- src/: Houses reference Python implementations and Jupyter notebooks for interactive experimentation.
- test/: Test cases for the implementations.
- *.ipynb: Jupyter notebooks for interactive playgrounds and tutorials.
We have implemented reference code for several MLE PCS schemes using Python. Python was chosen for its flexibility and readability, facilitating a better understanding of the underlying concepts. These implementations serve as a foundation for further research and experimentation.
Interactive Jupyter Notebooks are provided to serve as playgrounds and tutorials for experimenting with different PCS schemes. These notebooks allow users to run code snippets, visualize results, and gain hands-on experience with the algorithms.
- Basefold.ipynb: Tutorial and experiments related to the BaseFold PCS scheme.
- bcho_pcs.ipynb: Tutorial and experiments related to the BCHO PCS scheme.
- kzg10.ipynb: Implementation and analysis of the KZG10 PCS scheme.
- zeromorph.ipynb: Tutorial and experiments related to the Zeromorph PCS scheme.
- zeromorph_mapping_tutorial.ipynb: Step-by-step guide to the Zeromorph PCS mapping process.
Comprehensive research notes are available within each relevant folder, provided in both English and Chinese. These notes document our understanding, analysis, and insights into each PCS scheme.
- basefold/: Detailed notes on the BaseFold scheme.
- fri/: Insights and analysis on the FRI scheme.
- fri-binius/: Comprehensive exploration of the Binius-PCS scheme.
- zeromorph/: Tutorials and notes on Zeromorph PCS.
You can also find the PDF version of the research notes at https://sec-bit.github.io/mle-pcs/. Note PDF files may not be fully updated to the latest version.
📌 Request for Feedback: These notes are open for proofreading and reviewing. We welcome any advice, corrections, or suggestions to improve the content. Your contributions are highly appreciated!
📅 Upcoming Blog Posts: In the future, we plan to polish and publish these notes as blog posts to reach a wider audience and share our findings more broadly.
- Research and Experimental Purpose Only: This project is intended solely for research and experimental purposes.
- Not for Production Use: Do not use this code in any production environment. The implementations are reference codes aimed at understanding concepts better.
- Educational Value: The Python implementations provided are designed to be flexible and easy to understand, facilitating learning and further experimentation.
- Basefold
- Binius-PCS (for binary fields)
- FRI (for univariate polynomial only)
- Zeromorph (MLE-2-Uni adaptor)
- Brakedown-PCS
- Orion-PCS
- PH23(Logup)-PCS
- BCHO22(Gemini)-PCS
- Hyrax-PCS
- Libra-PCS
- Virgo-PCS
We encourage contributions from the community to enhance this project. If you would like to contribute, please fork the repository and submit a pull request or open an issue for discussion.
TODO: list current contributors
You can find guidelines for contributing to this project here.
- [DP23] Diamond, Benjamin E., and Jim Posen. "Succinct arguments over towers of binary fields." Cryptology ePrint Archive (2023).
- [KT23] Kohrita, Tohru, and Patrick Towa. "Zeromorph: Zero-knowledge multilinear-evaluation proofs from homomorphic univariate commitments." Cryptology ePrint Archive (2023).
- [BBHR18] Eli Ben-Sasson, Iddo Bentov, Ynon Horesh, and Michael Riabzev. Fast Reed-Solomon Interactive Oracle Proofs of Proximity. In Proceedings of the 45th International Colloquium on Automata, Languages, and Programming (ICALP), 2018. Available online as Report 134-17 on Electronic Colloquium on Computational Complexity.
- [BGKS20] Eli Ben-Sasson, Lior Goldberg, Swastik Kopparty, and Shubhangi Saraf. "DEEP-FRI: sampling outside the box improves soundness." arXiv preprint arXiv:1903.12243 (2019).
- [BCIKS20] Eli Ben-Sasson, Dan Carmon, Yuval Ishai, Swastik Kopparty, and Shubhangi Saraf. Proximity Gaps for Reed–Solomon Codes. In Proceedings of the 61st Annual IEEE Symposium on Foundations of Computer Science, pages 900–909, 2020.
- [ZCF23] Hadas Zeilberger, Binyi Chen, and Ben Fisch. "BaseFold: efficient field-agnostic polynomial commitment schemes from foldable codes." In Annual International Cryptology Conference, pp. 138-169. Cham: Springer Nature Switzerland, 2024.
- [H24] Ulrich Haböck. "Basefold in the List Decoding Regime." Cryptology ePrint Archive(2024).
- [ACFY24a] Gal Arnon, Alessandro Chiesa, Giacomo Fenzi, and Eylon Yogev. "STIR: Reed-Solomon proximity testing with fewer queries." In Annual International Cryptology Conference, pp. 380-413. Cham: Springer Nature Switzerland, 2024.
- [ACFY24b] Gal Arnon, Alessandro Chiesa, Giacomo Fenzi, and Eylon Yogev. "WHIR: Reed–Solomon Proximity Testing with Super-Fast Verification." Cryptology ePrint Archive (2024).
- [GLHQTZ24] Yanpei Guo, Xuanming Liu, Kexi Huang, Wenjie Qu, Tianyang Tao, and Jiaheng Zhang. "DeepFold: Efficient Multilinear Polynomial Commitment from Reed-Solomon Code and Its Application to Zero-knowledge Proofs." Cryptology ePrint Archive (2024).
- [DP24] Diamond, Benjamin E., and Jim Posen. "Polylogarithmic Proofs for Multilinears over Binary Towers." Cryptology ePrint Archive (2024).
- [BCH+22] Jonathan Bootle, Alessandro Chiesa, Yuncong Hu, and Michele Orru. "Gemini: Elastic SNARKs for diverse environments." In Annual International Conference on the Theory and Applications of Cryptographic Techniques, pp. 427-457. Cham: Springer International Publishing, 2022.
- [XZZPS19] Tiancheng Xie, Jiaheng Zhang, Yupeng Zhang, Charalampos Papamanthou, and Dawn Song. "Libra: Succinct Zero-Knowledge Proofs with Optimal Prover Computation." Cryptology ePrint Archive (2019). https://eprint.iacr.org/2019/317
- [KZG10] Kate, Aniket, Gregory M. Zaverucha, and Ian Goldberg. "Constant-size commitments to polynomials and their applications." Advances in Cryptology-ASIACRYPT 2010: 16th International Conference on the Theory and Application of Cryptology and Information Security, Singapore, December 5-9, 2010. Proceedings 16. Springer Berlin Heidelberg, 2010.
- [PST13] Papamanthou, Charalampos, Elaine Shi, and Roberto Tamassia. "Signatures of correct computation." Theory of Cryptography Conference. Berlin, Heidelberg: Springer Berlin Heidelberg, 2013. https://eprint.iacr.org/2011/587
- [CHMMVW19] Alessandro Chiesa, Yuncong Hu, Mary Maller, Pratyush Mishra, Psi Vesely, and Nicholas Ward. "Marlin: Preprocessing zkSNARKs with Universal and Updatable SRS." https://eprint.iacr.org/2019/1047
More are listed in the research notes.
We extend our gratitude to the Ethereum Foundation for funding this research. Special thanks to all the contributors and the cryptographic community for their continuous support and valuable insights.
Disclaimer: This project is for research and experimental purposes only. Please do not use this code in any production environment.