From 2d394aa58305dd029b09242e8484425fc143c105 Mon Sep 17 00:00:00 2001 From: lancenonce Date: Sat, 25 Feb 2023 10:54:22 -0700 Subject: [PATCH 1/3] Updated README --- README.md | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 1ad16ffaf..6fb01d0d0 100644 --- a/README.md +++ b/README.md @@ -66,7 +66,7 @@ You can easily create an `.onnx` file using `pytorch`. For samples of Onnx files These examples are also available as a submodule in `./examples/onnx`. To generate a proof on one of the examples, first build ezkl (`cargo build --release`) and add it to your favourite `PATH` variables, then generate a structured reference string (SRS): ```bash -ezkl --bits=16 -K=17 gen-srs --pfsys=kzg --params-path=kzg.params +ezkl -K=17 gen-srs --pfsys=kzg --params-path=kzg.params ``` ```bash @@ -90,13 +90,18 @@ cargo run --release --bin ezkl -- table -M ./examples/onnx/examples/1l_relu/netw #### verifying with the EVM ◊ Note that the above prove and verify stats can also be run with an EVM verifier. This can be done by generating a verifier smart contract after generating the proof + ```bash # gen proof ezkl --bits=16 -K=17 prove -D ./examples/onnx/examples/1l_relu/input.json -M ./examples/onnx/examples/1l_relu/network.onnx --proof-path 1l_relu.pf --vk-path 1l_relu.vk --params-path=kzg.params --transcript=evm +``` +```bash # gen evm verifier -target/release/ezkl -K=17 --bits=16 create-evm-verifier --pfsys=kzg --deployment-code-path 1l_relu.code --params-path=kzg.params --vk-path 1l_relu.vk --sol-code-path 1l_relu.sol +ezkl -K=17 --bits=16 create-evm-verifier -D ./examples/onnx/examples/1l_relu/input.json -M ./examples/onnx/examples/1l_relu/network.onnx --pfsys=kzg --deployment-code-path 1l_relu.code --params-path=kzg.params --vk-path 1l_relu.vk --sol-code-path 1l_relu.sol +``` +```bash # Verify (EVM) -target/release/ezkl -K=17 --bits=16 verify-evm --pfsys=kzg --proof-path 1l_relu.pf --deployment-code-path 1l_relu.code +ezkl -K=17 --bits=16 verify-evm --pfsys=kzg --proof-path 1l_relu.pf --deployment-code-path 1l_relu.code ``` Note that the `.sol` file above can be deployed and composed with other Solidity contracts, via a `verify()` function. Please read [this document](https://hackmd.io/QOHOPeryRsOraO7FUnG-tg) for more information about the interface of the contract, how to obtain the data needed for its function parameters, and its limitations. @@ -106,15 +111,26 @@ The above pipeline can also be run using [proof aggregation](https://ethresear.c ```bash # Single proof -> single proof we are going to feed into aggregation circuit. (Mock)-verifies + verifies natively as sanity check ezkl -K=17 --bits=16 prove --pfsys=kzg --transcript=poseidon --strategy=accum -D ./examples/onnx/examples/1l_relu/input.json -M ./examples/onnx/examples/1l_relu/network.onnx --proof-path 1l_relu.pf --params-path=kzg.params --vk-path=1l_relu.vk +``` + +```bash +# Generate a new SRS with 2^20 rows +ezkl -K=20 gen-srs --pfsys=kzg --params-path=kzg.params +``` +```bash # Aggregate -> generates aggregate proof and also (mock)-verifies + verifies natively as sanity check -ezkl -K=17 --bits=16 aggregate --transcript=evm -M ./examples/onnx/examples/1l_relu/network.onnx --pfsys=kzg --aggregation-snarks=1l_relu.pf --aggregation-vk-paths 1l_relu.vk --vk-path aggr_1l_relu.vk --proof-path aggr_1l_relu.pf --params-path=kzg.params +ezkl -K=17 --bits=16 aggregate --transcript=evm -M ./examples/onnx/examples/1l_relu/network.onnx --pfsys=kzg --aggregation-snarks=1l_relu.pf --aggregation-vk-paths 1l_relu.vk --vk-path aggr_1l_relu.vk --proof-path aggr_1l_relu.pf --params-path=kzg.params +``` +```bash # Generate verifier code -> create the EVM verifier code ezkl -K=17 --bits=16 aggregate create-evm-verifier-aggr --pfsys=kzg --deployment-code-path aggr_1l_relu.code --params-path=kzg.params --vk-path aggr_1l_relu.vk +``` +```bash # Verify (EVM) -> -target/release/ezkl -K=17 --bits=16 verify-evm --pfsys=kzg --proof-path aggr_1l_relu.pf --deployment-code-path aggr_1l_relu.code +ezkl -K=17 --bits=16 verify-evm --pfsys=kzg --proof-path aggr_1l_relu.pf --deployment-code-path aggr_1l_relu.code ``` From 071a4bc208661590f533e02bfb5b7c93e7a05053 Mon Sep 17 00:00:00 2001 From: lancenonce Date: Sat, 25 Feb 2023 11:01:38 -0700 Subject: [PATCH 2/3] .. --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 6fb01d0d0..5b678a381 100644 --- a/README.md +++ b/README.md @@ -114,7 +114,7 @@ ezkl -K=17 --bits=16 prove --pfsys=kzg --transcript=poseidon --strategy=accum -D ``` ```bash -# Generate a new SRS with 2^20 rows +# Generate a new 2^20 SRS ezkl -K=20 gen-srs --pfsys=kzg --params-path=kzg.params ``` From 6a1d55c34a6b09f614776765158eeb65ae1eb59f Mon Sep 17 00:00:00 2001 From: lancenonce Date: Sat, 25 Feb 2023 11:03:58 -0700 Subject: [PATCH 3/3] ... --- README.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/README.md b/README.md index 5b678a381..5c4ced510 100644 --- a/README.md +++ b/README.md @@ -108,16 +108,16 @@ Note that the `.sol` file above can be deployed and composed with other Solidity The above pipeline can also be run using [proof aggregation](https://ethresear.ch/t/leveraging-snark-proof-aggregation-to-achieve-large-scale-pbft-based-consensus/11588) to reduce proof size and verifying times, so as to be more suitable for EVM deployment. A sample pipeline for doing so would be: -```bash -# Single proof -> single proof we are going to feed into aggregation circuit. (Mock)-verifies + verifies natively as sanity check -ezkl -K=17 --bits=16 prove --pfsys=kzg --transcript=poseidon --strategy=accum -D ./examples/onnx/examples/1l_relu/input.json -M ./examples/onnx/examples/1l_relu/network.onnx --proof-path 1l_relu.pf --params-path=kzg.params --vk-path=1l_relu.vk -``` - ```bash # Generate a new 2^20 SRS ezkl -K=20 gen-srs --pfsys=kzg --params-path=kzg.params ``` +```bash +# Single proof -> single proof we are going to feed into aggregation circuit. (Mock)-verifies + verifies natively as sanity check +ezkl -K=17 --bits=16 prove --pfsys=kzg --transcript=poseidon --strategy=accum -D ./examples/onnx/examples/1l_relu/input.json -M ./examples/onnx/examples/1l_relu/network.onnx --proof-path 1l_relu.pf --params-path=kzg.params --vk-path=1l_relu.vk +``` + ```bash # Aggregate -> generates aggregate proof and also (mock)-verifies + verifies natively as sanity check ezkl -K=17 --bits=16 aggregate --transcript=evm -M ./examples/onnx/examples/1l_relu/network.onnx --pfsys=kzg --aggregation-snarks=1l_relu.pf --aggregation-vk-paths 1l_relu.vk --vk-path aggr_1l_relu.vk --proof-path aggr_1l_relu.pf --params-path=kzg.params