Skip to content

Commit

Permalink
Revert "Bring kimchi/generic-cols into Keccak branches"
Browse files Browse the repository at this point in the history
  • Loading branch information
querolita authored Nov 1, 2023
1 parent 294695a commit 878b495
Show file tree
Hide file tree
Showing 21 changed files with 76 additions and 139 deletions.
15 changes: 13 additions & 2 deletions kimchi/src/bench.rs
Original file line number Diff line number Diff line change
Expand Up @@ -77,7 +77,12 @@ impl BenchmarkCtx {
}

/// Produces a proof
pub fn create_proof(&self) -> (ProverProof<Vesta, OpeningProof<Vesta>>, Vec<Fp>) {
pub fn create_proof(
&self,
) -> (
ProverProof<Vesta, OpeningProof<Vesta>, KIMCHI_COLS>,
Vec<Fp>,
) {
// create witness
let witness: [Vec<Fp>; KIMCHI_COLS] = array::from_fn(|_| vec![1u32.into(); self.num_gates]);

Expand All @@ -97,7 +102,13 @@ impl BenchmarkCtx {
}

#[allow(clippy::type_complexity)]
pub fn batch_verification(&self, batch: &[(ProverProof<Vesta, OpeningProof<Vesta>>, Vec<Fp>)]) {
pub fn batch_verification(
&self,
batch: &[(
ProverProof<Vesta, OpeningProof<Vesta>, KIMCHI_COLS>,
Vec<Fp>,
)],
) {
// verify the proof
let batch: Vec<_> = batch
.iter()
Expand Down
30 changes: 11 additions & 19 deletions kimchi/src/circuits/argument.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,6 @@ use serde::{Deserialize, Serialize};
use super::{
expr::{constraints::ExprOps, Cache, ConstantExpr, Constants},
gate::{CurrOrNext, GateType},
wires::KIMCHI_COLS,
};
use CurrOrNext::{Curr, Next};

Expand All @@ -37,8 +36,8 @@ pub enum ArgumentType {
/// created with ArgumentData and F = Field or F = PrimeField, then the constraints
/// are built as expressions of real field elements and can be evaluated directly on
/// the witness without using the prover.
pub struct ArgumentEnv<F: 'static, T, const COLUMNS: usize = KIMCHI_COLS> {
data: Option<ArgumentData<F, COLUMNS>>,
pub struct ArgumentEnv<F: 'static, T> {
data: Option<ArgumentData<F>>,
phantom_data: PhantomData<T>,
}

Expand All @@ -52,14 +51,10 @@ impl<F, T> Default for ArgumentEnv<F, T> {
}
}

impl<F: Field, T: ExprOps<F>, const COLUMNS: usize> ArgumentEnv<F, T, COLUMNS> {
impl<F: Field, T: ExprOps<F>> ArgumentEnv<F, T> {
/// Initialize the environment for creating constraints of real field elements that can be
/// evaluated directly over the witness without the prover/verifier
pub fn create(
witness: ArgumentWitness<F, COLUMNS>,
coeffs: Vec<F>,
constants: Constants<F>,
) -> Self {
pub fn create(witness: ArgumentWitness<F>, coeffs: Vec<F>, constants: Constants<F>) -> Self {
ArgumentEnv {
data: Some(ArgumentData {
witness,
Expand Down Expand Up @@ -134,24 +129,24 @@ impl<F: Field, T: ExprOps<F>, const COLUMNS: usize> ArgumentEnv<F, T, COLUMNS> {
}

/// Argument environment data for constraints of field elements
pub struct ArgumentData<F: 'static, const COLUMNS: usize = KIMCHI_COLS> {
pub struct ArgumentData<F: 'static> {
/// Witness rows
pub witness: ArgumentWitness<F, COLUMNS>,
pub witness: ArgumentWitness<F>,
/// Gate coefficients
pub coeffs: Vec<F>,
/// Constants
pub constants: Constants<F>,
}

/// Witness data for a argument
pub struct ArgumentWitness<T, const COLUMNS: usize = KIMCHI_COLS> {
pub struct ArgumentWitness<T> {
/// Witness for current row
pub curr: [T; COLUMNS],
pub curr: Vec<T>,
/// Witness for next row
pub next: [T; COLUMNS],
pub next: Vec<T>,
}

impl<T, const COLUMNS: usize> std::ops::Index<(CurrOrNext, usize)> for ArgumentWitness<T, COLUMNS> {
impl<T> std::ops::Index<(CurrOrNext, usize)> for ArgumentWitness<T> {
type Output = T;

fn index(&self, idx: (CurrOrNext, usize)) -> &T {
Expand All @@ -173,10 +168,7 @@ pub trait Argument<F: PrimeField> {
const CONSTRAINTS: u32;

/// Constraints for this argument
fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
cache: &mut Cache,
) -> Vec<T>;
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, cache: &mut Cache) -> Vec<T>;

/// Returns the set of constraints required to prove this argument.
fn constraints(cache: &mut Cache) -> Vec<E<F>> {
Expand Down
39 changes: 9 additions & 30 deletions kimchi/src/circuits/expr.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2662,20 +2662,13 @@ pub mod constraints {
fn literal(x: F) -> Self;

// Witness variable
fn witness<const COLUMNS: usize>(
row: CurrOrNext,
col: usize,
env: Option<&ArgumentData<F, COLUMNS>>,
) -> Self;
fn witness(row: CurrOrNext, col: usize, env: Option<&ArgumentData<F>>) -> Self;

/// Coefficient
fn coeff<const COLUMNS: usize>(col: usize, env: Option<&ArgumentData<F, COLUMNS>>) -> Self;
fn coeff(col: usize, env: Option<&ArgumentData<F>>) -> Self;

/// Create a constant
fn constant<const COLUMNS: usize>(
expr: ConstantExpr<F>,
env: Option<&ArgumentData<F, COLUMNS>>,
) -> Self;
fn constant(expr: ConstantExpr<F>, env: Option<&ArgumentData<F>>) -> Self;

/// Cache item
fn cache(&self, cache: &mut Cache) -> Self;
Expand Down Expand Up @@ -2735,22 +2728,15 @@ pub mod constraints {
Expr::Constant(ConstantExpr::Literal(x))
}

fn witness<const COLUMNS: usize>(
row: CurrOrNext,
col: usize,
_: Option<&ArgumentData<F, COLUMNS>>,
) -> Self {
fn witness(row: CurrOrNext, col: usize, _: Option<&ArgumentData<F>>) -> Self {
witness(col, row)
}

fn coeff<const COLUMNS: usize>(col: usize, _: Option<&ArgumentData<F, COLUMNS>>) -> Self {
fn coeff(col: usize, _: Option<&ArgumentData<F>>) -> Self {
coeff(col)
}

fn constant<const COLUMNS: usize>(
expr: ConstantExpr<F>,
_: Option<&ArgumentData<F, COLUMNS>>,
) -> Self {
fn constant(expr: ConstantExpr<F>, _: Option<&ArgumentData<F>>) -> Self {
Expr::Constant(expr)
}

Expand Down Expand Up @@ -2800,28 +2786,21 @@ pub mod constraints {
x
}

fn witness<const COLUMNS: usize>(
row: CurrOrNext,
col: usize,
env: Option<&ArgumentData<F, COLUMNS>>,
) -> Self {
fn witness(row: CurrOrNext, col: usize, env: Option<&ArgumentData<F>>) -> Self {
match env {
Some(data) => data.witness[(row, col)],
None => panic!("Missing witness"),
}
}

fn coeff<const COLUMNS: usize>(col: usize, env: Option<&ArgumentData<F, COLUMNS>>) -> Self {
fn coeff(col: usize, env: Option<&ArgumentData<F>>) -> Self {
match env {
Some(data) => data.coeffs[col],
None => panic!("Missing coefficients"),
}
}

fn constant<const COLUMNS: usize>(
expr: ConstantExpr<F>,
env: Option<&ArgumentData<F, COLUMNS>>,
) -> Self {
fn constant(expr: ConstantExpr<F>, env: Option<&ArgumentData<F>>) -> Self {
match env {
Some(data) => expr.value(&data.constants),
None => panic!("Missing constants"),
Expand Down
15 changes: 6 additions & 9 deletions kimchi/src/circuits/gate.rs
Original file line number Diff line number Diff line change
Expand Up @@ -264,8 +264,7 @@ impl<F: PrimeField + SquareRootField> CircuitGate<F> {
zk_rows: cs.zk_rows,
};
// Create the argument environment for the constraints over field elements
let env =
ArgumentEnv::<F, F, COLUMNS>::create(argument_witness, self.coeffs.clone(), constants);
let env = ArgumentEnv::<F, F>::create(argument_witness, self.coeffs.clone(), constants);

// Check the wiring (i.e. copy constraints) for this gate
// Note: Gates can operated on row Curr or Curr and Next.
Expand Down Expand Up @@ -300,9 +299,7 @@ impl<F: PrimeField + SquareRootField> CircuitGate<F> {
// TODO: implement the verification for the generic gate
vec![]
}
GateType::Poseidon => {
poseidon::Poseidon::constraint_checks::<F, COLUMNS>(&env, &mut cache)
}
GateType::Poseidon => poseidon::Poseidon::constraint_checks(&env, &mut cache),
GateType::CompleteAdd => complete_add::CompleteAdd::constraint_checks(&env, &mut cache),
GateType::VarBaseMul => varbasemul::VarbaseMul::constraint_checks(&env, &mut cache),
GateType::EndoMul => endosclmul::EndosclMul::constraint_checks(&env, &mut cache),
Expand Down Expand Up @@ -361,7 +358,7 @@ impl<F: PrimeField + SquareRootField> CircuitGate<F> {
&self,
row: usize,
witness: &[Vec<F>; COLUMNS],
) -> CircuitGateResult<ArgumentWitness<F, COLUMNS>> {
) -> CircuitGateResult<ArgumentWitness<F>> {
// Get the part of the witness relevant to this gate
let witness_curr: [F; COLUMNS] = (0..witness.len())
.map(|col| witness[col][row])
Expand All @@ -378,9 +375,9 @@ impl<F: PrimeField + SquareRootField> CircuitGate<F> {
[F::zero(); COLUMNS]
};

Ok(ArgumentWitness::<F, COLUMNS> {
curr: witness_curr,
next: witness_next,
Ok(ArgumentWitness::<F> {
curr: witness_curr.to_vec(),
next: witness_next.to_vec(),
})
}
}
Expand Down
4 changes: 0 additions & 4 deletions kimchi/src/circuits/lookup/lookups.rs
Original file line number Diff line number Diff line change
Expand Up @@ -780,16 +780,12 @@ pub mod wasm {
lookup: bool,
range_check: bool,
foreign_field_mul: bool,
keccak_round: bool,
keccak_sponge: bool,
) -> LookupPatterns {
LookupPatterns {
xor,
lookup,
range_check,
foreign_field_mul,
keccak_round,
keccak_sponge,
}
}
}
Expand Down
4 changes: 4 additions & 0 deletions kimchi/src/circuits/lookup/tables/bits16.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ use super::BITS16_TABLE_ID;
//~ The lookup table for 16-bits

/// Returns the lookup table for all 16-bit values
///
/// # Panics
///
/// Will panic if `data` is invalid.
pub fn bits16_table<F: Field>() -> LookupTable<F> {
let mut data = vec![vec![]; 1];

Expand Down
4 changes: 4 additions & 0 deletions kimchi/src/circuits/lookup/tables/reset.rs
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,10 @@ use super::RESET_TABLE_ID;
//~ The first column contains the 16-bit values, and the second column contains their expansion to 64-bit values.

/// Returns the sparse lookup table
///
/// # Panics
///
/// Will panic if `data` is invalid.
pub fn reset_table<F: Field>() -> LookupTable<F> {
let mut data = vec![vec![]; 2];

Expand Down
4 changes: 4 additions & 0 deletions kimchi/src/circuits/lookup/tables/sparse.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,10 @@ use ark_ff::Field;
//~ This is a 1-column table containing the sparse representation of all 16-bit preimages.

/// Returns the sparse lookup table
///
/// # Panics
///
/// Will panic if `data` is invalid.
pub fn sparse_table<F: Field>() -> LookupTable<F> {
let mut data = vec![vec![]; 1];

Expand Down
4 changes: 4 additions & 0 deletions kimchi/src/circuits/lookup/tables/xor.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,10 @@ use ark_ff::Field;
//~ will translate into a scalar multiplication by 0, which is free.

/// Returns the XOR lookup table
///
/// # Panics
///
/// Will panic if `data` is invalid.
pub fn xor_table<F: Field>() -> LookupTable<F> {
let mut data = vec![vec![]; 3];

Expand Down
5 changes: 1 addition & 4 deletions kimchi/src/circuits/polynomials/complete_add.rs
Original file line number Diff line number Diff line change
Expand Up @@ -97,10 +97,7 @@ where
const ARGUMENT_TYPE: ArgumentType = ArgumentType::Gate(GateType::CompleteAdd);
const CONSTRAINTS: u32 = 7;

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, cache: &mut Cache) -> Vec<T> {
// This function makes 2 + 1 + 1 + 1 + 2 = 7 constraints
let x1 = env.witness_curr(0);
let y1 = env.witness_curr(1);
Expand Down
5 changes: 1 addition & 4 deletions kimchi/src/circuits/polynomials/endomul_scalar.rs
Original file line number Diff line number Diff line change
Expand Up @@ -167,10 +167,7 @@ where
const ARGUMENT_TYPE: ArgumentType = ArgumentType::Gate(GateType::EndoMulScalar);
const CONSTRAINTS: u32 = 11;

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, cache: &mut Cache) -> Vec<T> {
let n0 = env.witness_curr(0);
let n8 = env.witness_curr(1);
let a0 = env.witness_curr(2);
Expand Down
5 changes: 1 addition & 4 deletions kimchi/src/circuits/polynomials/endosclmul.rs
Original file line number Diff line number Diff line change
Expand Up @@ -186,10 +186,7 @@ where
const ARGUMENT_TYPE: ArgumentType = ArgumentType::Gate(GateType::EndoMul);
const CONSTRAINTS: u32 = 11;

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, cache: &mut Cache) -> Vec<T> {
let b1 = env.witness_curr(11);
let b2 = env.witness_curr(12);
let b3 = env.witness_curr(13);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -142,10 +142,7 @@ where
const ARGUMENT_TYPE: ArgumentType = ArgumentType::Gate(GateType::ForeignFieldAdd);
const CONSTRAINTS: u32 = 4;

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
_cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, _cache: &mut Cache) -> Vec<T> {
let foreign_modulus: [T; LIMB_COUNT] = array::from_fn(|i| env.coeff(i));

// stored as coefficient for better correspondance with the relation being proved
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -193,10 +193,7 @@ where
const CONSTRAINTS: u32 = 11;
// DEGREE is 4

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
_cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, _cache: &mut Cache) -> Vec<T> {
let mut constraints = vec![];

//
Expand Down
5 changes: 1 addition & 4 deletions kimchi/src/circuits/polynomials/generic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -74,10 +74,7 @@ where
const ARGUMENT_TYPE: ArgumentType = ArgumentType::Gate(GateType::Generic);
const CONSTRAINTS: u32 = 2;

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
_cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, _cache: &mut Cache) -> Vec<T> {
// First generic gate
let left_coeff1 = env.coeff(0);
let right_coeff1 = env.coeff(1);
Expand Down
5 changes: 1 addition & 4 deletions kimchi/src/circuits/polynomials/poseidon.rs
Original file line number Diff line number Diff line change
Expand Up @@ -337,10 +337,7 @@ where
const ARGUMENT_TYPE: ArgumentType = ArgumentType::Gate(GateType::Poseidon);
const CONSTRAINTS: u32 = 15;

fn constraint_checks<T: ExprOps<F>, const COLUMNS: usize>(
env: &ArgumentEnv<F, T, COLUMNS>,
cache: &mut Cache,
) -> Vec<T> {
fn constraint_checks<T: ExprOps<F>>(env: &ArgumentEnv<F, T>, cache: &mut Cache) -> Vec<T> {
let mut res = vec![];

let mut idx = 0;
Expand Down
Loading

0 comments on commit 878b495

Please sign in to comment.