You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

75 lines
2.4 KiB

// Copyright (c) 2023 Espresso Systems (espressosys.com)
// This file is part of the HyperPlonk library.
// You should have received a copy of the MIT License
// along with the HyperPlonk library. If not, see <https://mit-license.org/>.
//! This module implements useful functions for the permutation check protocol.
use crate::poly_iop::errors::PolyIOPErrors;
use arithmetic::identity_permutation_mles;
use ark_ff::PrimeField;
use ark_poly::DenseMultilinearExtension;
use ark_std::{end_timer, start_timer};
use std::sync::Arc;
/// Returns the evaluations of two list of MLEs:
/// - numerators = (a1, ..., ak)
/// - denominators = (b1, ..., bk)
///
/// where
/// - beta and gamma are challenges
/// - (f1, ..., fk), (g1, ..., gk),
/// - (s_id1, ..., s_idk), (perm1, ..., permk) are mle-s
///
/// - ai(x) is the MLE for `fi(x) + \beta s_id_i(x) + \gamma`
/// - bi(x) is the MLE for `gi(x) + \beta perm_i(x) + \gamma`
///
/// The caller is responsible for sanity-check
#[allow(clippy::type_complexity)]
pub(super) fn computer_nums_and_denoms<F: PrimeField>(
beta: &F,
gamma: &F,
fxs: &[Arc<DenseMultilinearExtension<F>>],
gxs: &[Arc<DenseMultilinearExtension<F>>],
perms: &[Arc<DenseMultilinearExtension<F>>],
) -> Result<
(
Vec<Arc<DenseMultilinearExtension<F>>>,
Vec<Arc<DenseMultilinearExtension<F>>>,
),
PolyIOPErrors,
> {
let start = start_timer!(|| "compute numerators and denominators");
let num_vars = fxs[0].num_vars;
let mut numerators = vec![];
let mut denominators = vec![];
let s_ids = identity_permutation_mles::<F>(num_vars, fxs.len());
for l in 0..fxs.len() {
let mut numerator_evals = vec![];
let mut denominator_evals = vec![];
for (&f_ev, (&g_ev, (&s_id_ev, &perm_ev))) in fxs[l]
.iter()
.zip(gxs[l].iter().zip(s_ids[l].iter().zip(perms[l].iter())))
{
let numerator = f_ev + *beta * s_id_ev + gamma;
let denominator = g_ev + *beta * perm_ev + gamma;
numerator_evals.push(numerator);
denominator_evals.push(denominator);
}
numerators.push(Arc::new(DenseMultilinearExtension::from_evaluations_vec(
num_vars,
numerator_evals,
)));
denominators.push(Arc::new(DenseMultilinearExtension::from_evaluations_vec(
num_vars,
denominator_evals,
)));
}
end_timer!(start);
Ok((numerators, denominators))
}