Han f64bfe6c2a Improve sum check in general and preprocess for sum check in mlkzg multi_open (#123)
* feat: faster sum check prover and multilinear kzg batching open

* fix: add comment about why we combine polys that have the same opening point

* fix: remove the unnecessary last eval increment
2023-02-14 11:49:58 -05:00
2023-01-12 22:30:35 +08:00
2023-01-24 12:10:53 +00:00
2022-10-13 23:21:30 -04:00
2023-01-24 12:10:53 +00:00
2023-01-12 22:29:03 +08:00
2023-01-24 12:10:53 +00:00
2023-01-24 12:10:53 +00:00
2022-04-20 17:10:25 -04:00
2022-10-13 23:21:30 -04:00
2023-01-12 22:30:35 +08:00
2023-01-12 22:30:35 +08:00
2023-01-24 12:10:53 +00:00
2023-01-18 08:56:37 -05:00
2022-04-20 17:10:25 -04:00
2023-01-12 22:30:35 +08:00

Hyperplonk library

A linear-time FFT-free SNARK proof system (https://eprint.iacr.org/2022/1355.pdf).

Disclaimer

DISCLAIMER: This software is provided "as is" and its security has not been externally audited. Use at your own risk.

Development environment setup

Install RUST

We recommend using nix for installing the correct version of rust and additional libraries:

> curl -L https://nixos.org/nix/install | sh

Compiling the project for the first time

> nix-shell
> cargo build

Direnv

We recommend the following tools:

Run direnv allow at the repo root. You should see dependencies (including Rust) being installed (the first time might take a while). Upon modification on flake.nix, run direnv reload to reflect new dependencies or environment setups.

Tests

> cargo test --release --all

Generate and read the documentation

Standard

> cargo doc --open

Code formatting

To format your code run

> cargo fmt

Updating non-cargo dependencies

Run nix flake update if you would like to pin other version edit flake.nix beforehand. Commit the lock file when happy.

To update only a single input specify it as an argument, for example

nix flake update github:oxalica/rust-overlay

Benchmarks

To obtain benchmarks, run the script file scripts/run_benchmarks.sh. We refer to Table 5 and Table 6 in https://eprint.iacr.org/2022/1355.pdf for an example benchmark.

Description
No description provided
Readme MIT 12 MiB
Languages
Rust 98.4%
Nix 1.1%
Shell 0.5%