From cf2b7cf4a70bb1e8ab90b1523308d28f217d5e68 Mon Sep 17 00:00:00 2001 From: TomAFrench Date: Wed, 15 Feb 2023 18:10:04 +0000 Subject: [PATCH] feat: receive `public_inputs` as a `BTreeMap` --- Cargo.lock | 174 +++++++++++------- .../src/acvm_interop/proof_system.rs | 4 +- .../src/acvm_interop/proof_system.rs | 9 +- .../src/acvm_interop/proof_system.rs | 9 +- common/Cargo.toml | 3 +- common/src/barretenberg_structures.rs | 7 + common/src/gadget_caller.rs | 1 + common/src/serialiser.rs | 1 + 8 files changed, 134 insertions(+), 74 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index b54c0e2e..cf871633 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -5,8 +5,7 @@ version = 3 [[package]] name = "acir" version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5d756bcab90b3a4a84dc53245890cf9bb8fcde31a1394931f5abca551b48eb20" +source = "git+https://github.com/noir-lang/acvm?branch=public-inputs-map#b84e591290392bc95a2fb035cb3254626a62d4c5" dependencies = [ "acir_field", "flate2", @@ -17,11 +16,11 @@ dependencies = [ [[package]] name = "acir_field" version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "deb7e1e30625a9125a0e700c6c6fd7442ffbcb1d235933100b791ba3786ef49e" +source = "git+https://github.com/noir-lang/acvm?branch=public-inputs-map#b84e591290392bc95a2fb035cb3254626a62d4c5" dependencies = [ "ark-bn254", "ark-ff", + "ark-serialize", "blake2", "cfg-if", "hex", @@ -33,13 +32,11 @@ dependencies = [ [[package]] name = "acvm" version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6c4fae94e7f3fe0d21bec4796de00bbf0cd8f781271b5203dea54897aa5387b9" +source = "git+https://github.com/noir-lang/acvm?branch=public-inputs-map#b84e591290392bc95a2fb035cb3254626a62d4c5" dependencies = [ "acir", "acvm_stdlib", "blake2", - "hex", "indexmap", "k256", "num-bigint", @@ -51,8 +48,7 @@ dependencies = [ [[package]] name = "acvm_stdlib" version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "eaf6617b72c2cd4e965d425bc768bb77a803e485a7e37cbc09cccc5967becd7a" +source = "git+https://github.com/noir-lang/acvm?branch=public-inputs-map#b84e591290392bc95a2fb035cb3254626a62d4c5" dependencies = [ "acir", ] @@ -83,6 +79,17 @@ dependencies = [ "version_check", ] +[[package]] +name = "ahash" +version = "0.8.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2c99f64d1e06488f620f932677e24bc6e2897582980441ae90a671415bd7ec2f" +dependencies = [ + "cfg-if", + "once_cell", + "version_check", +] + [[package]] name = "aho-corasick" version = "0.7.20" @@ -94,9 +101,9 @@ dependencies = [ [[package]] name = "ark-bn254" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ea691771ebbb28aea556c044e2e5c5227398d840cee0c34d4d20fa8eb2689e8c" +checksum = "a22f4561524cd949590d78d7d4c5df8f592430d221f7f3c9497bbafd8972120f" dependencies = [ "ark-ec", "ark-ff", @@ -105,29 +112,34 @@ dependencies = [ [[package]] name = "ark-ec" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dea978406c4b1ca13c2db2373b05cc55429c3575b8b21f1b9ee859aa5b03dd42" +checksum = "52d7f0c52aff14f216200a9eee06a9990fee2e51fc9599e226df448ad3232886" dependencies = [ "ark-ff", + "ark-poly", "ark-serialize", "ark-std", "derivative", + "hashbrown 0.13.2", + "itertools", "num-traits", "zeroize", ] [[package]] name = "ark-ff" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "6b3235cc41ee7a12aaaf2c575a2ad7b46713a8a50bda2fc3b003a04845c05dd6" +checksum = "51ee31d8869a353433524dbd5a8f51f95cdafe7c66d458956ec13aa737198562" dependencies = [ "ark-ff-asm", "ark-ff-macros", "ark-serialize", "ark-std", "derivative", + "digest 0.10.6", + "itertools", "num-bigint", "num-traits", "paste", @@ -137,9 +149,9 @@ dependencies = [ [[package]] name = "ark-ff-asm" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "db02d390bf6643fb404d3d22d31aee1c4bc4459600aef9113833d17e786c6e44" +checksum = "3fc8f7ec7fdcc20f3f110783c043d80479b42f500003cf92b71ca90f34a2ba0e" dependencies = [ "quote", "syn", @@ -147,31 +159,58 @@ dependencies = [ [[package]] name = "ark-ff-macros" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "db2fd794a08ccb318058009eefdf15bcaaaaf6f8161eb3345f907222bac38b20" +checksum = "15aa320e38052d644e569740bad208e5f9f5fafedcc9e6b1557f723be1b7ff8d" dependencies = [ "num-bigint", "num-traits", + "proc-macro2", "quote", "syn", ] +[[package]] +name = "ark-poly" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "88d2e8741caf33ab3063f1fc65617716ffb18cba8e872998aa2eef0d4e4b56d1" +dependencies = [ + "ark-ff", + "ark-serialize", + "ark-std", + "derivative", + "hashbrown 0.13.2", +] + [[package]] name = "ark-serialize" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1d6c2b318ee6e10f8c2853e73a83adc0ccb88995aa978d8a3408d492ab2ee671" +checksum = "58ea39d00a8a4c832e6f6520e58ccec7bf909c4845863512e9b8656fd47df355" dependencies = [ + "ark-serialize-derive", "ark-std", - "digest", + "digest 0.10.6", + "num-bigint", +] + +[[package]] +name = "ark-serialize-derive" +version = "0.4.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "101333772a4020c883890811500d5ecc704c545a90140629af5c3b9f00d78953" +dependencies = [ + "proc-macro2", + "quote", + "syn", ] [[package]] name = "ark-std" -version = "0.3.0" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "1df2c09229cbc5a028b1d70e00fdb2acee28b1055dfb5ca73eea49c5a25c4e7c" +checksum = "94893f1e0c6eeab764ade8dc4c0db24caf4fe7cbbaafc0eba0a9030f447b5185" dependencies = [ "num-traits", "rand", @@ -304,7 +343,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "0a4e37d16930f5459780f5621038b6382b9bb37c19016f39fb6b5808d831f174" dependencies = [ "crypto-mac 0.8.0", - "digest", + "digest 0.9.0", "opaque-debug", ] @@ -586,6 +625,16 @@ dependencies = [ "cfg-if", ] +[[package]] +name = "crypto-common" +version = "0.1.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1bfb12502f3fc46cca1bb51ac28df9d618d813cdc3d2f25b9fe775a34af26bb3" +dependencies = [ + "generic-array", + "typenum", +] + [[package]] name = "crypto-mac" version = "0.8.0" @@ -669,6 +718,15 @@ dependencies = [ "generic-array", ] +[[package]] +name = "digest" +version = "0.10.6" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8168378f4e5023e7218c89c891c0fd8ecdb5e5e4f18cb78f38cf245dd021e76f" +dependencies = [ + "crypto-common", +] + [[package]] name = "dirs" version = "3.0.2" @@ -726,7 +784,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "f2db227e61a43a34915680bdda462ec0e212095518020a88a1f91acd16092c39" dependencies = [ "bitvec", - "digest", + "digest 0.9.0", "ff", "funty", "generic-array", @@ -1051,7 +1109,7 @@ version = "0.11.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "ab5ef0d4909ef3724cc8cce6ccc8572c5c817592e9285f5464f8e86f8bd3726e" dependencies = [ - "ahash", + "ahash 0.7.6", ] [[package]] @@ -1060,7 +1118,16 @@ version = "0.12.3" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "8a9ee70c43aaf417c914396645a0fa852624801b24ebb7ae78fe8272889ac888" dependencies = [ - "ahash", + "ahash 0.7.6", +] + +[[package]] +name = "hashbrown" +version = "0.13.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "43a3c133739dddd0d2990f9a4bdf8eb4b21ef50e4851ca85ab661199821d510e" +dependencies = [ + "ahash 0.8.3", ] [[package]] @@ -1094,7 +1161,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "c1441c6b1e930e2817404b5046f1f989899143a12bf92de603b69f4e0aee1e15" dependencies = [ "crypto-mac 0.10.1", - "digest", + "digest 0.9.0", ] [[package]] @@ -1228,6 +1295,15 @@ version = "2.7.1" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "30e22bd8629359895450b59ea7a776c850561b96a3b1d31321c1949d9e6c9146" +[[package]] +name = "itertools" +version = "0.10.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b0fd2260e829bddf4cb6ea802289de2f86d6a7a690192fbe91b3f46e0f2c8473" +dependencies = [ + "either", +] + [[package]] name = "itoa" version = "1.0.5" @@ -1557,16 +1633,6 @@ version = "2.2.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "478c572c3d73181ff3c2539045f6eb99e5491218eae919370993b890cdbdd98e" -[[package]] -name = "pest" -version = "2.5.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "028accff104c4e513bad663bbcd2ad7cfd5304144404c31ed0a77ac103d00660" -dependencies = [ - "thiserror", - "ucd-trie", -] - [[package]] name = "pin-project-lite" version = "0.2.9" @@ -1913,9 +1979,9 @@ checksum = "08d43f7aa6b08d49f382cde6a7982047c3426db949b1424bc4b7ec9ae12c6ce2" [[package]] name = "rustc_version" -version = "0.3.3" +version = "0.4.0" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f0dfe2087c51c460008730de8b57e6a320782fbfb312e1f4d520e6c6fae155ee" +checksum = "bfa0f585226d2e68097d4f95d113b15b83a82e819ab25717ec0590d9584ef366" dependencies = [ "semver", ] @@ -1977,21 +2043,9 @@ checksum = "1c107b6f4780854c8b126e228ea8869f4d7b71260f962fefb57b996b8959ba6b" [[package]] name = "semver" -version = "0.11.0" +version = "1.0.16" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "f301af10236f6df4160f7c3f04eec6dbc70ace82d23326abad5edee88801c6b6" -dependencies = [ - "semver-parser", -] - -[[package]] -name = "semver-parser" -version = "0.10.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "00b0bef5b7f9e0df16536d3961cfb6e84331c065b4066afb39768d0e319411f7" -dependencies = [ - "pest", -] +checksum = "58bc9567378fc7690d6b2addae4e60ac2eeea07becb2c64b9f218b53865cba2a" [[package]] name = "serde" @@ -2054,7 +2108,7 @@ dependencies = [ "block-buffer", "cfg-if", "cpufeatures", - "digest", + "digest 0.9.0", "opaque-debug", ] @@ -2070,7 +2124,7 @@ version = "1.2.2" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "29f060a7d147e33490ec10da418795238fd7545bba241504d6b31a409f2e6210" dependencies = [ - "digest", + "digest 0.9.0", "rand_core 0.5.1", ] @@ -2325,12 +2379,6 @@ version = "1.16.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "497961ef93d974e23eb6f433eb5fe1b7930b659f06d12dec6fc44a8f554c0bba" -[[package]] -name = "ucd-trie" -version = "0.1.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9e79c4d996edb816c91e4308506774452e55e95c3c9de07b6729e17e15a5ef81" - [[package]] name = "unicode-bidi" version = "0.3.10" diff --git a/barretenberg_js/src/acvm_interop/proof_system.rs b/barretenberg_js/src/acvm_interop/proof_system.rs index 680f91a8..d7c7e3c8 100644 --- a/barretenberg_js/src/acvm_interop/proof_system.rs +++ b/barretenberg_js/src/acvm_interop/proof_system.rs @@ -42,7 +42,7 @@ impl ProofSystemCompiler for Plonk { fn verify_from_cs( &self, proof: &[u8], - public_inputs: Vec, + public_inputs: BTreeMap, circuit: Circuit, ) -> bool { let serialized = circuit.to_bytes(); @@ -51,7 +51,7 @@ impl ProofSystemCompiler for Plonk { // Prepend the public inputs to the proof let mut proof_with_pub_inputs = Vec::new(); - for pi in public_inputs { + for pi in public_inputs.values() { proof_with_pub_inputs.extend(pi.to_bytes()) } proof_with_pub_inputs.extend(proof); diff --git a/barretenberg_static_lib/src/acvm_interop/proof_system.rs b/barretenberg_static_lib/src/acvm_interop/proof_system.rs index cd9af6a3..d0f299b1 100644 --- a/barretenberg_static_lib/src/acvm_interop/proof_system.rs +++ b/barretenberg_static_lib/src/acvm_interop/proof_system.rs @@ -38,14 +38,14 @@ impl ProofSystemCompiler for Plonk { fn verify_from_cs( &self, proof: &[u8], - public_inputs: Vec, + public_inputs: BTreeMap, circuit: Circuit, ) -> bool { let constraint_system = serialise_circuit(&circuit); let mut composer = StandardComposer::new(constraint_system); - composer.verify(proof, Some(Assignments::from_vec(public_inputs))) + composer.verify(proof, Some(Assignments::from_map(public_inputs))) } fn np_language(&self) -> Language { @@ -60,6 +60,7 @@ impl ProofSystemCompiler for Plonk { fn black_box_function_supported(&self, opcode: &common::acvm::acir::BlackBoxFunc) -> bool { match opcode { + common::acvm::acir::BlackBoxFunc::Keccak256 => todo!(), common::acvm::acir::BlackBoxFunc::AES => false, common::acvm::acir::BlackBoxFunc::AND => true, common::acvm::acir::BlackBoxFunc::XOR => true, @@ -115,7 +116,7 @@ impl ProofSystemCompiler for Plonk { fn verify_with_vk( &self, proof: &[u8], - public_inputs: Vec, + public_inputs: BTreeMap, circuit: Circuit, verification_key: Vec, ) -> bool { @@ -124,7 +125,7 @@ impl ProofSystemCompiler for Plonk { composer.verify_with_vk( proof, - Some(Assignments::from_vec(public_inputs)), + Some(Assignments::from_map(public_inputs)), &verification_key, ) } diff --git a/barretenberg_wasm/src/acvm_interop/proof_system.rs b/barretenberg_wasm/src/acvm_interop/proof_system.rs index 3ec9958d..3e978f55 100644 --- a/barretenberg_wasm/src/acvm_interop/proof_system.rs +++ b/barretenberg_wasm/src/acvm_interop/proof_system.rs @@ -39,14 +39,14 @@ impl ProofSystemCompiler for Plonk { fn verify_from_cs( &self, proof: &[u8], - public_inputs: Vec, + public_inputs: BTreeMap, circuit: Circuit, ) -> bool { let constraint_system = common::serialiser::serialise_circuit(&circuit); let mut composer = StandardComposer::new(constraint_system); - composer.verify(proof, Some(Assignments::from_vec(public_inputs))) + composer.verify(proof, Some(Assignments::from_map(public_inputs))) } fn np_language(&self) -> Language { @@ -63,6 +63,7 @@ impl ProofSystemCompiler for Plonk { fn black_box_function_supported(&self, opcode: &common::acvm::acir::BlackBoxFunc) -> bool { match opcode { + common::acvm::acir::BlackBoxFunc::Keccak256 => todo!(), common::acvm::acir::BlackBoxFunc::AES => false, common::acvm::acir::BlackBoxFunc::AND => true, common::acvm::acir::BlackBoxFunc::XOR => true, @@ -119,7 +120,7 @@ impl ProofSystemCompiler for Plonk { fn verify_with_vk( &self, proof: &[u8], - public_inputs: Vec, + public_inputs: BTreeMap, circuit: Circuit, verification_key: Vec, ) -> bool { @@ -128,7 +129,7 @@ impl ProofSystemCompiler for Plonk { composer.verify_with_vk( proof, - Some(Assignments::from_vec(public_inputs)), + Some(Assignments::from_map(public_inputs)), &verification_key, ) } diff --git a/common/Cargo.toml b/common/Cargo.toml index b68eef55..ed4d44cc 100644 --- a/common/Cargo.toml +++ b/common/Cargo.toml @@ -6,7 +6,8 @@ edition = "2021" # See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html [dependencies] -acvm = { version = "0.4.1", features = ["bn254"] } +#acvm = { version = "0.4.1", features = ["bn254"] } +acvm = { git = "https://github.com/noir-lang/acvm", branch = "public-inputs-map", features = ["bn254"] } sled = "0.34.6" blake2 = "0.9.1" diff --git a/common/src/barretenberg_structures.rs b/common/src/barretenberg_structures.rs index 830b1555..44c28238 100644 --- a/common/src/barretenberg_structures.rs +++ b/common/src/barretenberg_structures.rs @@ -1,3 +1,6 @@ +use std::collections::BTreeMap; + +use acvm::acir::native_types::Witness; pub use acvm::FieldElement as Scalar; #[derive(Debug, Clone)] @@ -22,6 +25,10 @@ impl Assignments { Assignments(vec) } + pub fn from_map(map: BTreeMap) -> Assignments { + Assignments(map.into_values().collect()) + } + pub fn push_i32(&mut self, value: i32) { self.0.push(Scalar::from(value as i128)); } diff --git a/common/src/gadget_caller.rs b/common/src/gadget_caller.rs index 42561a25..968a4fb7 100644 --- a/common/src/gadget_caller.rs +++ b/common/src/gadget_caller.rs @@ -29,6 +29,7 @@ pub fn solve_blackbox_func_call( gadget_call: &BlackBoxFuncCall, ) -> Result<(), OpcodeResolutionError> { match gadget_call.name { + BlackBoxFunc::Keccak256 => todo!(), BlackBoxFunc::SHA256 => pwg::hash::sha256(initial_witness, gadget_call), BlackBoxFunc::Blake2s => pwg::hash::blake2s(initial_witness, gadget_call), BlackBoxFunc::EcdsaSecp256k1 => { diff --git a/common/src/serialiser.rs b/common/src/serialiser.rs index 4d554d54..86d3ced8 100644 --- a/common/src/serialiser.rs +++ b/common/src/serialiser.rs @@ -33,6 +33,7 @@ pub fn serialise_circuit(circuit: &Circuit) -> ConstraintSystem { } Opcode::BlackBoxFuncCall(gadget_call) => { match gadget_call.name { + BlackBoxFunc::Keccak256 => todo!(), BlackBoxFunc::RANGE => { assert_eq!(gadget_call.inputs.len(), 1); assert_eq!(gadget_call.outputs.len(), 0);