Traits
BaseAire
contains width(the number of columns) and preprocessed_trace(what is this used for?)
data:image/s3,"s3://crabby-images/d5a26/d5a26a8995fb411cc48da5f586032dc0b9fcd99a" alt=""
AirBuilderWithPublicValues
it extend the AirBuilder trait, which is the main trait, by adding the function to get public values
data:image/s3,"s3://crabby-images/e85b5/e85b5b9693077f65e46421600e5a2ad7ef1ed39f" alt=""
AirBuilder
data:image/s3,"s3://crabby-images/85000/850002303c28caaa4fcf7617e1a9ef33af064558" alt=""
it has many functions like these: to help user build air constraints
data:image/s3,"s3://crabby-images/c9f0d/c9f0d9a8dbac23a7d8e9848ad5507c8efdd48a33" alt=""
The main function return M, M is a Matrix, seems to be the core data struct to store constraints information?
Prove function
Plonk recap:
Debugging notes
initialized trace
trace is stores in the RowMajorMatrix, which is a DenseMatrix.
data:image/s3,"s3://crabby-images/2af5c/2af5cc8a63fdb44f1beeea1b3484ac2a9f71505e" alt=""
the trace is flatten to values, then use width to record the number of the cols.
the trace passed to the prove function is
INFO i [info]: trace after computation is DenseMatrix { values: [0, 1, 1, 1, 1, 2, 2, 3, 3, 5, 5, 8, 8, 13, 13, 21], width: 2, _phantom: PhantomData<p3_monty_31::monty_31::MontyField31<p3_baby_bear::baby_bear::BabyBearParameters>> }
get the degree of the cols, namely, the length of the column and restrict it to be power of 2
data:image/s3,"s3://crabby-images/c2ada/c2adadfdb8474c1211553338d4b67f1e9f651c25" alt=""
there are 5 constraints:
data:image/s3,"s3://crabby-images/57c75/57c75eb94161c7f486609855e51f26e3544d79ff" alt=""
constraint degree is 2 is because when_first_row means a multiplication to isFirstRow
data:image/s3,"s3://crabby-images/96e64/96e64a3c51f23d323b3a84c42587521612727c71" alt=""
explanation line by line
let quotient_domain =
trace_domain.create_disjoint_domain(1 << (log_degree + log_quotient_degree));
quotient domain is double the log size of (trace log degree and quotient degree)
Explanation:
- suppose the is one witness traces: \(f(x)\), the quotient polynomial will be computed like this (constraint degree is 1):
\(\frac{f(x)}{(x-w_0)(x-w_1)…(x-w_n)}\)
if this is computed in the trace domain, the denominator will be evaluated to 0, this doesn’t mean that you only need a constant to present the quotient polynomial, instead, you need at least the trace domain size to present the quotient poly and then verify it to be a constant!
- suppose there are three witness traces: \(f(x),g(x),c(x)\), the quotient polynomial will be computed like this (constraint degree is 2):
\(\frac{f(x)g(x)-c(x)}{(x-w_0)(x-w_1)…(x-w_n)}\)
then the degree of the
the prove function has input type air, here is the Fibonacci air, the air parameter and air.eval function belongs to Fibonacci air
data:image/s3,"s3://crabby-images/0c997/0c997b13f4e01ae826b00ff842e0a8b25a24f004" alt=""
let quotient_values = quotient_values(
air,
public_values,
trace_domain,// size 8
quotient_domain, // size log_degree + log_quotient_degree 8
trace_on_quotient_domain,
alpha,
constraint_count,
);
the quotient_values function is one of the core
this folder function seems fold all the constraint to one constraint, need to know how exactly it is folded.
data:image/s3,"s3://crabby-images/ba872/ba8720bf78fd6c00ddde5ea3db75e9c83d1d7a55" alt=""