The reason I write this is because I saw the verification sample ood points are related to InfoEvalator. InfoEvalator contains this mask or mask offset information which basically embedded the circuit information.
This mask points of MleEvalProverComponent
data:image/s3,"s3://crabby-images/f8033/f80339b24ba311324a9e7d31d3157e9b8adb9e86" alt=""
Start with component built
when a component is buit, it takes a location_allocator, PowdrEval (type implement FrameworkEval), and logup_sums.
data:image/s3,"s3://crabby-images/5bed7/5bed710abb2d163797fa88aeb55f265baefb494c" alt=""
-> new function of Component (trait FrameworkComponent): PowdrEval.evaluate function is called, upon infoevaluator, is where the mask_offset start building
data:image/s3,"s3://crabby-images/da86d/da86d077f4f923a40e5140129c993d9e3f8d5a92" alt=""
struct of Infoevaluator is defined as
data:image/s3,"s3://crabby-images/efaca/efacab9898cffc94ce705aad277a22f1cb6e3f5b" alt=""
The important field mask_offsets is updated every time a new column, or new interaction is built, by calling function next_trace_mask or get_preprocessed_column
data:image/s3,"s3://crabby-images/ac15c/ac15c9ce0625354c37570370e1bc3f9622959c57" alt=""
data:image/s3,"s3://crabby-images/65bba/65bba42afa652041917594448ace53f85688d721" alt=""
mask_offset has this structure:
- it has three vectors to present pre-processed columns, let’s call them interation vector, interaction 0 is pre-processed, 1 is witness cols, 2 is for logup
- each interaction vector contains vectors to present columns. let’s call them column vectors
- each column vectors contains values to present the position/evaluation/values that build circuit relation.
data:image/s3,"s3://crabby-images/58a56/58a56cdb0997219dbf636da1f5aca06b416e19d7" alt=""
here this vector below present three columns, each column contains two values that used for computing circuit relations. offset 1 is for the next reference.
[[0, 1], [0, 1], [0, 1]]
Now let’s go back to the mask_point used in verification sample points
mask point is a function defined in component trait:
data:image/s3,"s3://crabby-images/1539d/1539d483dac113fa9c8931e2828c88bd3c4c5599" alt=""
you see, it is for the SecureField
there are two struct implement this function, one is frameworkComponent, the other one is Mlecomponent …
FrameworkComponent mask_points
FrameworkComponent: it transfer the offset to secure field point, then use it to evaluate the circuit
data:image/s3,"s3://crabby-images/072a2/072a2794a6e1db85f8079cb61d0f4672b451a4ba" alt=""
you can see the oods point, it is the same values with the place where offset is 0
data:image/s3,"s3://crabby-images/fff71/fff71db9e2f8eddedd1f640967bf3a1f8cb90db1" alt=""
frameworkComponent is defined as:
data:image/s3,"s3://crabby-images/78284/7828404fa033d21e0caf4e3112d2733760ff9680" alt=""
basically the InfoEvaluator is where it stores all the circuit info
the output of the mask_points of frameworkComponent is
data:image/s3,"s3://crabby-images/d200f/d200f25f6c508472a224f367fa194500d7b364ba" alt=""
Sample points in Verification function
One interesting observation: in verification function, verifier use mask_points of the components to get sample points based on the oods point. while these sampled points are not put into the evaluation function to get the composition_oods_eval, instead, the check for composition_ood_eval gets inputs from proof.sampled_values.
data:image/s3,"s3://crabby-images/d7c91/d7c91028136a3609506d7c4dd6502145f0195a72" alt=""
proof.sampled_values looks like this:
data:image/s3,"s3://crabby-images/e9bad/e9bad77b7c1cf5de41c198b78c9c38ce3288199e" alt=""
while the sample_points looks like:
data:image/s3,"s3://crabby-images/e6c2a/e6c2ac7c5b026a3ca0105345752f917ccf1e12ca" alt=""
it seems these sampled_values are actually from witness columns directly.
note that when verifier computes the compsition_odds_eval, verifier’s information includes:
- oods point
- proof.sampled values
- random_coeff
the components contains circuit information, how the verifier can get the evaluation?
how the sampled_values in the proof come from?
let see how it is used in the verification function first.
it is used in the check for the composition_oods_eval
data:image/s3,"s3://crabby-images/906eb/906eb3b125f44bd89df62ed49dfebb3759e41dfe" alt=""
-> eval_composition_polynomial_at_point function, it accumulate the evaluate_constraint_quotients_at_point from every components
data:image/s3,"s3://crabby-images/d1fac/d1fac6554d77fef496aa67ebed32cc5e30616f03" alt=""
after the modification I made following up the call with tibo, I had error: too few queried values.
data:image/s3,"s3://crabby-images/f772e/f772e56f97efa592e60b19fd4680b87e7d23a182" alt=""
this problem happens in MerkleProver verification function to Verifies the decommitment of the columns
data:image/s3,"s3://crabby-images/1c7b3/1c7b3d5a7fa2c2f4ea5f252af3e5dbdfcb0dd929" alt=""
The queried values is
data:image/s3,"s3://crabby-images/69017/690176d8b4c4caa58043bba1de33349adbfa08f4" alt=""