Skip to content

Commit

Permalink
plonk: multiprover: proof-system: Ingest ark-mpc interface changes
Browse files Browse the repository at this point in the history
  • Loading branch information
joeykraut committed Jun 15, 2024
1 parent 1eac22f commit daa22a6
Show file tree
Hide file tree
Showing 7 changed files with 63 additions and 10 deletions.
61 changes: 57 additions & 4 deletions plonk/src/multiprover/proof_system/prover.rs
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ use crate::{
proof_system::structs::{CommitKey, ProvingKey},
};

use super::{MpcArithmetization, MpcOracles};
use super::MpcArithmetization;

// -------------------------
// | Prover Implementation |
Expand Down Expand Up @@ -710,7 +710,7 @@ impl<E: Pairing> MpcProver<E> {
// with t_lowest_i(X) = t_lowest_i(X) - 0 + b_now_i * X^(n+2)
// and t_highest_i(X) = t_highest_i(X) - b_last_i
let mut last_randomizer = self.fabric.zero_authenticated();
let mut randomizers = self.fabric.random_shared_scalars_authenticated(num_wire_types - 1);
let mut randomizers = self.fabric.random_shared_scalars(num_wire_types - 1);

split_quot_polys.iter_mut().take(num_wire_types - 1).for_each(|poly| {
poly.coeffs[0] = &poly.coeffs[0] - &last_randomizer;
Expand Down Expand Up @@ -934,10 +934,12 @@ pub fn mul_poly_result<C: CurveGroup>(

#[cfg(test)]
pub(crate) mod test {
use ark_ec::CurveGroup;
use ark_ff::{One, Zero};
use ark_mpc::{
algebra::{AuthenticatedDensePoly, Scalar},
beaver::ZeroBeaverSource,
algebra::{AuthenticatedDensePoly, Scalar, ScalarShare},
network::PartyId,
offline_prep::PreprocessingPhase,
test_helpers::{execute_mock_mpc, execute_mock_mpc_with_beaver_source},
MpcFabric, PARTY0, PARTY1,
};
Expand All @@ -961,6 +963,57 @@ pub(crate) mod test {

use super::MpcProver;

/// A beaver source that always returns zero
#[cfg(any(feature = "test_helpers", test))]
struct ZeroBeaverSource {
/// The ID of the local party
party_id: PartyId,
}

impl ZeroBeaverSource {
/// Create a new beaver source given the local party_id
pub fn new(party_id: PartyId) -> Self {
Self { party_id }
}
}

impl<C: CurveGroup> PreprocessingPhase<C> for ZeroBeaverSource {
fn get_mac_key_share(&self) -> Scalar<C> {
Scalar::zero()
}

fn next_local_input_mask(&mut self) -> (Scalar<C>, ScalarShare<C>) {
(Scalar::zero(), ScalarShare::new(Scalar::zero(), Scalar::zero()))
}

fn next_counterparty_input_mask(&mut self) -> ScalarShare<C> {
ScalarShare::new(Scalar::zero(), Scalar::zero())
}

fn next_shared_bit(&mut self) -> ScalarShare<C> {
ScalarShare::new(Scalar::zero(), Scalar::zero())
}

fn next_triplet(&mut self) -> (ScalarShare<C>, ScalarShare<C>, ScalarShare<C>) {
let zero = ScalarShare::new(Scalar::zero(), Scalar::zero());
(zero, zero, zero)
}

/// For the shared inverse pair, we return 1 to give a valid member of
/// the multiplicative subgroup
///
/// This means that each party holds their party ID as a shared value
fn next_shared_inverse_pair(&mut self) -> (ScalarShare<C>, ScalarShare<C>) {
let val = Scalar::from(self.party_id);
let share = ScalarShare::new(val, val);
(share, share)
}

fn next_shared_value(&mut self) -> ScalarShare<C> {
ScalarShare::new(Scalar::zero(), Scalar::zero())
}
}

/// Get a randomized set of challenges
fn randomized_challenges() -> Challenges<TestScalar> {
let mut rng = thread_rng();
Expand Down
2 changes: 1 addition & 1 deletion primitives/benches/merkle_path.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
// You should have received a copy of the MIT License
// along with the Jellyfish library. If not, see <https://mit-license.org/>.

#![deny(warnings)]
// #![deny(warnings)]
#[macro_use]
extern crate criterion;
use ark_ed_on_bls12_381::Fq as Fq381;
Expand Down
2 changes: 1 addition & 1 deletion primitives/benches/reed_solomon.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
// You should have received a copy of the MIT License
// along with the Jellyfish library. If not, see <https://mit-license.org/>.

#![deny(warnings)]
// #![deny(warnings)]
#[macro_use]
extern crate criterion;
use ark_bn254::Fr as Fr254;
Expand Down
2 changes: 1 addition & 1 deletion primitives/src/elgamal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -260,7 +260,7 @@ where
P: Config<BaseField = F>,
{
/// Decryption function
fn decrypt(&self, ctext: &Ciphertext<P>) -> Vec<P::BaseField> {
pub fn decrypt(&self, ctext: &Ciphertext<P>) -> Vec<P::BaseField> {
let perm = Permutation::default();
let shared_key = (ctext.ephemeral.key * self.key).into_affine();
let key =
Expand Down
2 changes: 1 addition & 1 deletion primitives/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
//! well as the plonk circuit implementation of those primitives.
#![cfg_attr(not(feature = "std"), no_std)]
#![deny(warnings)]
// #![deny(warnings)]
#![deny(missing_docs)]
#![allow(unknown_lints)]
#[cfg(test)]
Expand Down
2 changes: 1 addition & 1 deletion primitives/src/rescue/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
//!
//! Those three place holders should never be used.
#![deny(warnings)]
// #![deny(warnings)]
pub mod errors;
mod rescue_constants;
pub mod sponge;
Expand Down
2 changes: 1 addition & 1 deletion rust-toolchain
Original file line number Diff line number Diff line change
@@ -1 +1 @@
nightly-2023-08-19
nightly-2024-02-26

0 comments on commit daa22a6

Please sign in to comment.