halo2/src/plonk/lookup.rs

39 lines
1.1 KiB
Rust
Raw Normal View History

2020-11-30 22:53:20 -08:00
use super::circuit::{Any, Column};
2021-01-20 05:47:55 -08:00
pub(crate) mod prover;
pub(crate) mod verifier;
2020-11-30 22:53:20 -08:00
#[derive(Clone, Debug)]
pub(crate) struct Argument {
pub input_columns: Vec<Column<Any>>,
pub table_columns: Vec<Column<Any>>,
}
impl Argument {
pub fn new(input_columns: &[Column<Any>], table_columns: &[Column<Any>]) -> Self {
assert_eq!(input_columns.len(), table_columns.len());
Argument {
input_columns: input_columns.to_vec(),
table_columns: table_columns.to_vec(),
}
}
pub(crate) fn required_degree(&self) -> usize {
assert_eq!(self.input_columns.len(), self.table_columns.len());
// degree 2:
// l_0(X) * (1 - z'(X)) = 0
//
// degree 3:
// z'(X) (a'(X) + \beta) (s'(X) + \gamma)
// - z'(\omega^{-1} X) (\theta^{m-1} a_0(X) + ... + a_{m-1}(X) + \beta) (\theta^{m-1} s_0(X) + ... + s_{m-1}(X) + \gamma)
//
// degree 2:
// l_0(X) * (a'(X) - s'(X)) = 0
//
// degree 2:
// (a(X)s(X))⋅(a(X)a(\omega{-1} X)) = 0
3
}
2020-11-30 22:53:20 -08:00
}