Skip to content
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

Merged
merged 27 commits into from
Feb 16, 2023
Merged
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
98379a6
initial preprocess cmd to test backend changes
vezenovm Feb 2, 2023
ec07827
merge conflicts
vezenovm Feb 6, 2023
61b0fcb
cargo lock merge conflicts
vezenovm Feb 6, 2023
bb26ce7
initial work using preprocess for nargo proving and verification, sti…
vezenovm Feb 7, 2023
24eff9f
use fixed up aztec_backend for preprocess
vezenovm Feb 9, 2023
37949b2
moving preprocess into compile command
vezenovm Feb 9, 2023
dcee05c
use nargo compile to preprocess no more preprocess cmd
vezenovm Feb 9, 2023
c14b00e
remove preprocess cmd file
vezenovm Feb 9, 2023
5665ffc
remove TODO from nargo cargo.toml
vezenovm Feb 9, 2023
c3f1960
merge conflicts
vezenovm Feb 14, 2023
34e5e65
add checking of acir file in nargo prove
vezenovm Feb 14, 2023
16ee9ac
switch to using circuit_path for pk and vk paths, compare compiled ci…
vezenovm Feb 14, 2023
0e6a44c
add logic to look at checksum of acir rather than the file byte by bte
vezenovm Feb 14, 2023
babe68b
merge conflicts with combined prove and verify cmd
vezenovm Feb 14, 2023
5add0bd
remove debug
vezenovm Feb 15, 2023
e11e29b
cargo update
vezenovm Feb 15, 2023
29d11c4
remove unnecessary comments
vezenovm Feb 15, 2023
57158bb
switch backend reference to updated composer
vezenovm Feb 15, 2023
90b3294
when build artifacts are not provided to nargo prove, preprocess as a…
vezenovm Feb 16, 2023
a1864a5
move fetch_pk_and_vk into main nargo module, also use hash cs method …
vezenovm Feb 16, 2023
5d8db6b
move path specifications to separate method in nargo commands
vezenovm Feb 16, 2023
9ea4cec
comment in compile cmd
vezenovm Feb 16, 2023
3f76f1e
nit comments and cspell
vezenovm Feb 16, 2023
3c9e953
update aztec_backend commit rev
vezenovm Feb 16, 2023
189defd
merge conflicts
vezenovm Feb 16, 2023
eab26bf
merge conflicts
vezenovm Feb 16, 2023
f600459
cargo fmt after merge
vezenovm Feb 16, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -9,5 +9,8 @@ pkg/
# Nargo output
*.proof
*.acir
*.acir.sha256
*.tr
*.pk
*.vk
**/Verifier.toml
100 changes: 62 additions & 38 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

4 changes: 2 additions & 2 deletions crates/nargo/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -31,8 +31,8 @@ termcolor = "1.1.2"
tempdir = "0.3.7"

# Backends
aztec_backend = { optional = true, package = "barretenberg_static_lib", git = "https://github.com/noir-lang/aztec_backend", rev = "d0e1257c22618f98f53781faba3c372ef91a0172" }
aztec_wasm_backend = { optional = true, package = "barretenberg_wasm", git = "https://github.com/noir-lang/aztec_backend", rev = "d0e1257c22618f98f53781faba3c372ef91a0172" }
aztec_backend = { optional = true, package = "barretenberg_static_lib", git = "https://github.com/noir-lang/aztec_backend", rev = "cff757dca7971161e4bd25e7a744d910c37c22be" }
aztec_wasm_backend = { optional = true, package = "barretenberg_wasm", git = "https://github.com/noir-lang/aztec_backend", rev = "cff757dca7971161e4bd25e7a744d910c37c22be" }
marlin_arkworks_backend = { optional = true, git = "https://github.com/noir-lang/marlin_arkworks_backend", rev = "144378edad821bfaa52bf2cacca8ecc87514a4fc" }

[features]
Expand Down
75 changes: 64 additions & 11 deletions crates/nargo/src/cli/compile_cmd.rs
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
use clap::ArgMatches;
use std::path::{Path, PathBuf};

use acvm::ProofSystemCompiler;
use acvm::{acir::circuit::Circuit, hash_constraint_system};
use clap::ArgMatches;
use noirc_abi::input_parser::Format;
use std::path::{Path, PathBuf};

use super::{add_std_lib, create_named_dir, read_inputs_from_file, write_to_file};
use crate::{
cli::execute_cmd::save_witness_to_dir,
constants::{ACIR_EXT, PROVER_INPUT_FILE, TARGET_DIR},
constants::{ACIR_EXT, PK_EXT, PROVER_INPUT_FILE, TARGET_DIR, VK_EXT},
errors::CliError,
resolver::Resolver,
};
Expand All @@ -33,7 +33,6 @@ pub(crate) fn run(args: ArgMatches) -> Result<(), CliError> {
.map(|_| ())
}

#[allow(deprecated)]
pub fn generate_circuit_and_witness_to_disk<P: AsRef<Path>>(
circuit_name: &str,
program_dir: P,
Expand All @@ -42,13 +41,12 @@ pub fn generate_circuit_and_witness_to_disk<P: AsRef<Path>>(
allow_warnings: bool,
) -> Result<PathBuf, CliError> {
let compiled_program = compile_circuit(program_dir.as_ref(), false, allow_warnings)?;
let serialized = compiled_program.circuit.to_bytes();

let mut circuit_path = create_named_dir(circuit_dir.as_ref(), "build");
circuit_path.push(circuit_name);
circuit_path.set_extension(ACIR_EXT);
let path = write_to_file(serialized.as_slice(), &circuit_path);
println!("Generated ACIR code into {path}");
preprocess_with_path(circuit_name, circuit_dir.as_ref(), compiled_program.circuit.clone())?;

let mut circuit_path =
save_acir_to_dir(compiled_program.circuit.clone(), circuit_name, circuit_dir.as_ref());
println!("Generated ACIR code into {}", circuit_path.display());

if generate_witness {
// Parse the initial witness values from Prover.toml
Expand Down Expand Up @@ -82,3 +80,58 @@ pub fn compile_circuit<P: AsRef<Path>>(
.into_compiled_program(backend.np_language(), show_ssa, allow_warnings)
.map_err(|_| std::process::exit(1))
}

pub fn preprocess_with_path<P: AsRef<Path>>(
key_name: &str,
preprocess_dir: P,
circuit: Circuit,
) -> Result<(PathBuf, PathBuf), CliError> {
let backend = crate::backends::ConcreteBackend;

let (proving_key, verification_key) = backend.preprocess(circuit);

let pk_path = save_key_to_dir(proving_key, key_name, &preprocess_dir, true)?;
println!("Proving key saved to {}", pk_path.display());
let vk_path = save_key_to_dir(verification_key, key_name, preprocess_dir, false)?;
println!("Verification key saved to {}", vk_path.display());

Ok((pk_path, vk_path))
}

fn save_acir_to_dir<P: AsRef<Path>>(
circuit: Circuit,
circuit_name: &str,
circuit_dir: P,
) -> PathBuf {
let mut circuit_path = create_named_dir(circuit_dir.as_ref(), "target");
circuit_path.push(circuit_name);

// Save a checksum of the circuit to compare against during proving and verification
let acir_hash = hash_constraint_system(&circuit);
circuit_path.set_extension(ACIR_EXT.to_owned() + ".sha256");
write_to_file(hex::encode(acir_hash).as_bytes(), &circuit_path);

let mut serialized = Vec::new();
circuit.write(&mut serialized).expect("could not serialize circuit");

circuit_path.set_extension(ACIR_EXT);
write_to_file(serialized.as_slice(), &circuit_path);

circuit_path
}

fn save_key_to_dir<P: AsRef<Path>>(
key: Vec<u8>,
key_name: &str,
key_dir: P,
is_proving_key: bool,
) -> Result<PathBuf, CliError> {
let mut key_path = create_named_dir(key_dir.as_ref(), key_name);
key_path.push(key_name);
let extension = if is_proving_key { PK_EXT } else { VK_EXT };
key_path.set_extension(extension);

write_to_file(hex::encode(key).as_bytes(), &key_path);

Ok(key_path)
}
Loading