-
Notifications
You must be signed in to change notification settings - Fork 204
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(nargo): Update nargo to use preprocessing interface #765
Conversation
…ll have non-deterministic error on backend with C++
…rcuit to one written to file
This PR should not be merged until noir-lang/acvm-backend-barretenberg#50 is in master. But it is ready for any feedback as all tests are passing using the new preprocess methods for proving and verification. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'm not a huge fan of the requirement to nargo compile
before nargo prove
. Ideally using preprocessed keys would be optional with the fallback being compiling the local program and using that.
I think it would also be nice to encapsulate the loading of keys/ACIR to remove the mutable path manipulations from business logic (Something similar to how read_inputs_from_file
does it)
… fallback, still needs to be done for verification
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good, can we add "preprocess" to CSpell as we're getting a lot of warnings coming up?
This LGTM so happy to merge once the backend dep is updated. |
@TomAFrench Had to dismiss due to merge conflicts if you could approve once more :) |
I'll approve in Tom's stead |
Related issue(s)
Resolves issue #820
Resolves issue noir-lang/acvm#65 and noir-lang/acvm#46 in ACVM
Description
This PR adds the ability to generate proving and verification keys using nargo.
The preprocess interface changes can be found in the ACVM: noir-lang/acvm#71 (merged)
The barretenberg methods to enable implementing this can be found here: noir-lang/aztec-connect#21 (merged)
The
aztec_backend
PR integrating the barretenberg changes above are in this PR: noir-lang/acvm-backend-barretenberg#50 (yet to be merged)The
aztec_backend
dependency inCargo.toml
references the branch in theaztec_backend
PR listed above.Summary of changes
There is a new
preprocess_with_path
method under thenargo compile
that allows a developer to generate the proving and verification keys necessary for the new ACVM interface methods. The proving and verification keys are written to the target directory with the file extensions.pk
and.vk
respectively.We also now write a sha256 checksum of the ACIR to the
target
directory during compilation. If someone has provided a name for their circuit build artifacts we later use this checksum duringnargo prove
andnargo verify
to determine whether the circuit someone is trying to prove or verify a has changed (otherwise the proving and verification keys will be incorrect). If the circuit has changed we issue an error telling the user that they should runnargo compile
again to regenerate the proving and verification keys. If a circuit name has not been provided fornargo prove
we fallback to regenerating the proving and verification keys keys.Regenerating the keys on a
nargo prove
ornargo verify
is technically what was happening before so this isn't going backwards. This is also mainly useful for a dev quickly iterating on circuits who would like to just runnargo prove
once. It will just be that if someone wants to get the performance benefits from not re-generating proving and verification keys, they will have to run nargo compile and pass a circuit_name to nargo prove and nargo verify. And then if someone is iterating on circuits and don't want to be re-running nargo compile, nargo prove --verify is their best choice.Dependency additions / changes
Currently referencing this PR in
aztec_backend
: noir-lang/acvm-backend-barretenberg#50. More details can be found in the Description section above.Test additions / changes
I altered the
prove_and_verify
helper method for our noir integration tests to generate proving and verification keys before calling our nargo commands for proving and verifying.Checklist
cargo fmt
with default settings.Additional context
To achieve the fastest proving and verification, a user should construct their build artifacts once with
nargo compile
.I used
time
on my local intel Mac to get a sense of how the nargo commands have changed. These are testing the times for circuits basing their proving and verification off of the build artifacts.1_mul - CURRENT MASTER
nargo prove p
- 1.82snargo verify p
- 1.90s1_mul - NEW
nargo compile c
- 1.04snargo prove p c
- 0.90s (2x speedup)nargo verify p c
- 0.73s (2.6x speedup)8_integration - CURRENT MASTER
nargo prove p
- 7.76snargo verify p
- 7.75s8_integration - NEW
nargo compile c
- 7.60snargo prove p c
- 5.38s (1.44x speedup)nargo verify p c
- 0.95s (8.15x speedup)9_conditional - CURRENT MASTER
nargo prove p
- 14.61snargo verify p
- 12.91s9_conditional - NEW
nargo compile c
- 23.58snargo prove p c
- 20.63s (slow down :/ looking at how we can reduce this, most likely due to reading in a large proving key + circuit)nargo verify p c
- 1.22s (10.5x speedup)