diff --git a/CHANGELOG.md b/CHANGELOG.md index 70ff246..67d2982 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -7,6 +7,12 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +## [0.40.0] - 2024-08-14 + +### Changed + +- Update to `dusk-plonk` v0.20 + ## [0.39.0] - 2024-05-08 ### Changed @@ -550,7 +556,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 [#112]: https://github.com/dusk-network/poseidon252/issues/112 -[Unreleased]: https://github.com/dusk-network/poseidon252/compare/v0.39.0...HEAD +[Unreleased]: https://github.com/dusk-network/poseidon252/compare/v0.40.0...HEAD +[0.40.0]: https://github.com/dusk-network/poseidon252/compare/v0.39.0...v0.40.0 [0.39.0]: https://github.com/dusk-network/poseidon252/compare/v0.38.0...v0.39.0 [0.38.0]: https://github.com/dusk-network/poseidon252/compare/v0.37.0...v0.38.0 [0.37.0]: https://github.com/dusk-network/poseidon252/compare/v0.36.0...v0.37.0 diff --git a/Cargo.toml b/Cargo.toml index 8a4e5c8..85d20ba 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "dusk-poseidon" -version = "0.39.0" +version = "0.40.0" description = "Implementation of Poseidon hash algorithm over the Bls12-381 Scalar field." categories = ["algorithms", "cryptography", "no-std", "wasm"] keywords = ["cryptography", "zero-knowledge", "crypto"] @@ -12,7 +12,7 @@ license = "MPL-2.0" [dependencies] dusk-bls12_381 = { version = "0.13", default-features = false, features = ["zeroize"] } dusk-jubjub = { version = "0.14", default-features = false } -dusk-plonk = { version = "0.19", default-features = false, features = ["alloc", "zeroize"], optional = true } +dusk-plonk = { version = "0.20", default-features = false, features = ["alloc", "zeroize"], optional = true } dusk-safe = "0.2" [dev-dependencies] diff --git a/decrypt.rs b/decrypt.rs deleted file mode 100644 index 67338ca..0000000 --- a/decrypt.rs +++ /dev/null @@ -1,115 +0,0 @@ -// This Source Code Form is subject to the terms of the Mozilla Public -// License, v. 2.0. If a copy of the MPL was not distributed with this -// file, You can obtain one at http://mozilla.org/MPL/2.0/. -// -// Copyright (c) DUSK NETWORK. All rights reserved. - -use dusk_poseidon::{decrypt, decrypt_gadget}; - -use criterion::{black_box, criterion_group, criterion_main, Criterion}; -use dusk_jubjub::GENERATOR; -use dusk_plonk::prelude::*; -use ff::Field; -use rand::rngs::StdRng; -use rand::SeedableRng; - -use std::ops::Mul; - -const CAPACITY: usize = 11; -const MESSAGE_CAPACITY: usize = 2; -const CIPHER_SIZE: usize = MESSAGE_CAPACITY + 1; - -#[derive(Default)] -pub struct CipherDecrypt { - shared: JubJubAffine, - nonce: BlsScalar, - cipher: PoseidonCipher, -} - -impl CipherDecrypt { - pub fn random(rng: &mut StdRng) -> Self { - let shared = GENERATOR - .to_niels() - .mul(&JubJubScalar::random(&mut *rng)) - .into(); - let nonce = BlsScalar::random(&mut *rng); - let message = - [BlsScalar::random(&mut *rng), BlsScalar::random(&mut *rng)]; - let cipher = PoseidonCipher::encrypt(&message, &shared, &nonce); - - Self { - shared, - nonce, - cipher, - } - } -} - -impl Circuit for CipherDecrypt { - fn circuit(&self, composer: &mut Composer) -> Result<(), Error> { - let shared = composer.append_point(self.shared); - let nonce = composer.append_witness(self.nonce); - - let mut cipher_circuit = [Composer::ZERO; CIPHER_SIZE]; - self.cipher - .cipher() - .iter() - .zip(cipher_circuit.iter_mut()) - .for_each(|(cipher_scalar, cipher_witness)| { - *cipher_witness = composer.append_witness(*cipher_scalar); - }); - - decrypt_gadget(composer, &shared, nonce, &cipher_circuit); - - Ok(()) - } -} - -// Benchmark cipher decryption -fn bench_cipher_decryption(c: &mut Criterion) { - // Prepare benchmarks and initialize variables - let label = b"cipher decryption benchmark"; - let mut rng = StdRng::seed_from_u64(0xc001); - let pp = PublicParameters::setup(1 << CAPACITY, &mut rng).unwrap(); - let (prover, verifier) = Compiler::compile::(&pp, label) - .expect("Circuit should compile successfully"); - let mut proof = Proof::default(); - let public_inputs = Vec::new(); - let circuit = CipherDecrypt::random(&mut rng); - - // Benchmark native cipher decryption - c.bench_function("cipher decryption native", |b| { - b.iter(|| { - PoseidonCipher::decrypt( - black_box(&circuit.cipher), - black_box(&circuit.shared), - black_box(&circuit.nonce), - ); - }) - }); - - // Benchmark proof creation - c.bench_function("cipher decryption proof generation", |b| { - b.iter(|| { - (proof, _) = prover - .prove(&mut rng, black_box(&circuit)) - .expect("Proof generation should succeed"); - }) - }); - - // Benchmark proof verification - c.bench_function("cipher decryption proof verification", |b| { - b.iter(|| { - verifier - .verify(black_box(&proof), &public_inputs) - .expect("Proof verification should succeed"); - }) - }); -} - -criterion_group! { - name = benches; - config = Criterion::default().sample_size(10); - targets = bench_cipher_decryption -} -criterion_main!(benches);