# Zero knowledge proofs

RISC Zero looks neat.

## Notes

## Links

- ZKP in WebAssembly
- Bulletproofs - Short Proofs for Confidential Transactions and More.
- Pure-Rust implementation of Bulletproofs using Ristretto
- Awesome zero knowledge proofs
- Arithmetic Circuits - Low-level representation of a program that consists of gates computing arithmetic operations of addition and multiplication, with wires connecting the gates.
- Visualizing Efficient Merkle Trees for Zero-Knowledge Proofs (2020)
- ZKP - Practical zero knowledge proof system that provides small and computationally efficient zero-knowledge proofs of arbitrary computations.
- Zero-knowledge attestation (2019)
- genSTARK - Library for generating zk-STARKs.
- Zero-Knowledge: a tutorial by Oded Goldreich
- Zinc framework - Goal of Zinc is to make writing safe zero-knowledge programs and ZKP-based smart contracts easy.
- A Field Guide to zkSNARKs (2020)
- Circom - Language designed to write arithmetic circuits that can be used in zero knowledge proofs.
- Zero-Knowledge Proofs for Engineers: Introduction (2020)
- Why and How zk-Snark Works (2019) (HN)
- SCIPR Lab - Succinct Computational Integrity and Privacy Research. (GitHub)
- gnark - Fast, open-source library for zero-knowledge proof protocols written in Go.
- Reverie: An optimized zero-knowledge proof system (2020)
- Tau Prolog - Prolog interpreter in JavaScript. (Code)
- Zero Knowledge Paillier - Collection of Paillier cryptosystem zero knowledge proofs written in Rust.
- rapidsnark - zkSnark proof generation.
- An approximate introduction to how zk-SNARKs are possible (2021)
- OpenZKP - Pure Rust implementations of Zero-Knowledge Proof systems.
- zkp - Experimental zero-knowledge proof compiler in Rust macros. (Fork)
- Zero Knowledge Proof - Numberphile (2021)
- Serving up zero-knowledge proofs (2021)
- Leo - Functional, statically-typed programming language built for writing private applications.
- Aleo - Where Applications Become Zero-Knowledge. (GitHub) (Twitter)
- Noir - Domain specific language for zero knowledge proofs.
- snarkOS - Decentralized Operating System for Zero-Knowledge Applications.
- snarkVM - Virtual Machine for Zero-Knowledge Executions.
- Aleo SDK - Software Development Kit (SDK) for Zero-Knowledge Transactions.
- wasmsnark - Fast zkSnark proof generator written in native Web Assembly.
- Zero-Knowledge Proofs (HN)
- Zk-SNARKs, FreeTON and OCamlPro
- Zero-Knowledge Middleboxes (2021) (Code) (HN)
- How do modern zero-knowledge proofs, and PLONK specifically, work? (videos) (2021)
- Zero-Knowledge Proofs for Private Web Attestation with Multi-Vendor Hardware (2021) (HN)
- snarkyJS - TypeScript/JavaScript framework for writing zk-SNARKs and snapps.
- circom - zkSnark circuit compiler.
- zkSNARKs Library - Library of zkSNARKS circuits written in the Circom language.
- arkworks::std - Standard library wrapper for use in the
`arkworks`

ecosystem. - Proof Systems - Contains various zk-SNARK protocol implementations for recursive SNARK composition.
- Polygon Miden - Zero-knowledge virtual machine written in Rust.
- Plonky - Recursive SNARKs based on Plonk and Halo.
- Plonky2 - SNARK implementation based on techniques from PLONK and FRI.
- Mir Protocol - Open-source platform that allows anyone to run private and scalable decentralized applications / ZKP-powered. (Twitter)
- snarkjs - ZkSNARK implementation in JavaScript & WASM.
- Learning zero knowledge proof technologies in public
- PLONK - Pure Rust PLONK implementation using arkworks as a backend.
- Understanding Zero-knowledge proofs through illustrated examples (2019) (HN)
- libsnark - C++ library for zkSNARK proofs.
- arkworks-gadgets - Zero-knowledge gadgets for blockchain applications.
- CirC - Compiling high-level languages for SMT, zero-knowledge proofs, and more.
- Gemini - Elastic proof system based on arkworks.
- Zero knowledge proofs using the Bulletproofs implementation from dalek-cryptography
- ZKDocs - Comprehensive, detailed, and interactive documentation on zero-knowledge proof systems and related primitives. (Code)
- zkUtil - Tool to work with zkSNARK circuits generated by Circom compiler.
- Interactive zero knowledge 3-colorability demonstration (HN)
- WordLines - Zero-knowledge proof-based blockchain puzzle game. (HN)
- AirScript - Scripting language for defining zk-STARKs.
- zkInterface - Protocol for the interoperability of zero-knowledge frameworks.
- Short-lived zero-knowledge proofs and signatures (2022) (Tweet)
- Introduction to Zero Knowledge Proofs
- Curve ecGFp5 - Elliptic curve defined over a field.
- RISC Zero - Zero-knowledge verifiable general computing platform based on zk-STARKs and the RISC-V microarchitecture.
- Awesome Zero Knowledge
- Arbibot RPS - On chain rock paper scissors game using zero knowledge proofs for hiding plays.
- zkSNARKS tutorial: practical beginner's guide to creating, proving, and verifying zkSNARKs in your contracts
- Jellyfish cryptographic library - Rust Implementation of the PLONK ZKP System and Extensions.
- Security of ZKP projects: same but different (Slides)
- Zero Knowledge Summit Amsterdam 2022
- Curated list of ZK resources and links
- Zk app boilerplate - Build your zkp app with typescript, hardhat, circom, and snarkjs.
- Zero Knowledge Proof using Hamiltonian Cycles (2016)
- Zero Knowledge Proofs of Knowledge (2016)
- zkPairing - Proof-of-concept implementations of elliptic curve pairings (in particular, the optimal Ate pairing and Tate pairing) for the BLS12-381 curve in circom.
- What are Zero Knowledge Proofs (ZKPs), and how are they changing blockchain forever?
- boo-hoo - Library for Non-Interactive Zero-Knowledge Proofs of Knowledge (NIZKPoKs) for boolean circuits.
- zkGames - Platform that allows users to play zk (zero knowledge) games and mint an NFT as proof that they have won.
- Exploring Zero Knowledge: StarkWare (2022)