following note1
packed31 is a vector of length 16
data:image/s3,"s3://crabby-images/1f636/1f63648f159404ebbd8fdaaea138c49ccb73d643" alt=""
data:image/s3,"s3://crabby-images/dc8d1/dc8d10c98d8d86e1201e637b649a91588107e5fe" alt=""
data:image/s3,"s3://crabby-images/9591f/9591f2b8ee4b9ef20da5da73040913aad2a9d071" alt=""
try to understand how the trace is generated
data:image/s3,"s3://crabby-images/47338/47338405d2cae754d2ffcdcef36c85082c794163" alt=""
the bottom lines actually transfer the M31 values into circleDomain
data:image/s3,"s3://crabby-images/940cc/940cc1fe06ff6a6eb041e8dc6a7baa5729ebdd29" alt=""
from start:
data:image/s3,"s3://crabby-images/1a552/1a552409cf50fe3fb6e17aba3f1f81f35959c340" alt=""
N is log N instances
data:image/s3,"s3://crabby-images/1020f/1020f4ee2fa82c2bd89fd078a4032e8e3bd23150" alt=""
this code is to initialise the witness columns, later use to store the witness.
this code generate N numbers of BaseColumns, each based columns has length 2^log_size, but it is presented by chunks of 16 length each, as packedM31.
data:image/s3,"s3://crabby-images/57d31/57d312ecd7e4bbb1392d1eef0d9231fa575e5a37" alt=""
Constraints
in the code, the constraints is generated by component
data:image/s3,"s3://crabby-images/e7fe3/e7fe39bbbe224f3f73719e9a475923afa9a8d3ff" alt=""
wideFibonacciComponent is a FrameworkComponent that has general type C which implement FrameworkEval, FrameworkEval requires to defined a function evaluate which has general type E that implement EvalAtRow
WideFibonacciComponent is defined like this
data:image/s3,"s3://crabby-images/1ded6/1ded6812ffb96736edbd9444e6ac90523b839542" alt=""
frameworkComponent is defined like this
data:image/s3,"s3://crabby-images/8566c/8566c19f492dd01de807b7059a052999de2ac3d8" alt=""
when perceive eval, remember it is a type that implement FrameworkEval, which doesn’t mean it is a struct called FrameworkEval
FrameworkEval looks like this, it is a trait!!!
data:image/s3,"s3://crabby-images/5ecb6/5ecb678ff41a3eb21aacdc04945f1e22e225d78d" alt=""
EvalAtRow looks like this
where all the operations defined
data:image/s3,"s3://crabby-images/ba78b/ba78b294170bc9d2cd31c6cd48b215f3286195ec" alt=""
new function for a generate a new component
data:image/s3,"s3://crabby-images/5fd49/5fd494426592daa632ac5a36282ca4f7d9b4a894" alt=""
this piece of code generate a
data:image/s3,"s3://crabby-images/8ac87/8ac8791bd44de078b6779e2ad01305d4ca59c2e3" alt=""
FIB sequence length is 32
log n instance is 6
implementation of FrameworkEval for WideFibonacciEval,
data:image/s3,"s3://crabby-images/8361d/8361dd3bbc9c9e357f936327f2612e2ee804e26d" alt=""
The most important function here is evaluate, which generate the fibonacci constraint
let’t understand it!
so the eval is a place to store all the constraint, it is AssertEvaluator struct
data:image/s3,"s3://crabby-images/2b715/2b715f14065e4698181e1947506e9b4f1dbb914a" alt=""
the evaluate function has input eval restricted by E EvalatRow
data:image/s3,"s3://crabby-images/60b04/60b04eb6bb18ce63bf1437abab3cc01504862455" alt=""
and the function is called like this
data:image/s3,"s3://crabby-images/efe2b/efe2b034ec3b4a12f392d3b51b1fca3c8dda26b2" alt=""
which means eval as AssertEvaluator should implemented EvalatRow
let’s see how it looks:
data:image/s3,"s3://crabby-images/a5b05/a5b0539d73a64e65ae76b755231f377476645f4d" alt=""
recall the component of AssertEvaluator
data:image/s3,"s3://crabby-images/b3d88/b3d8808ca0eb70618350903c3f73e9ec32a28028" alt=""
TreeVec
is essentially a wrapper around a Vec
(a dynamically-sized array in Rust)
data:image/s3,"s3://crabby-images/83f8e/83f8e074af9fa804bdcbf933022c7b4d2993ec25" alt=""
The new function take a trace, create a vector that has the same length with the trace
the trait EvalAtRow has these functions need to be defined:
data:image/s3,"s3://crabby-images/0b303/0b303a631276c420835a5bcf62cfb476f876cc74" alt=""
let’s start digging into this one
data:image/s3,"s3://crabby-images/1afa3/1afa3a73e30503d489eafd142eaba37477e57dbc" alt=""
The AssertEvaluator’s implementation for next_interaction mask is:
data:image/s3,"s3://crabby-images/8cd99/8cd992373bc710894e254c6b548b42d5ffea6e23" alt=""
trace is a TreeVec<Vec<Vec<BaseField>>>
it can be something like this:
self.trace = [
[ [1, 2, 3], [4, 5], [6] ],
[ [7, 8], [9, 10, 11] ]
];
when indexing TreeVec[], it find a set of witness for a single fibonacci instance, indexing TreeVec[][] find a specific witness trace (from the same vaiable!) like find [1,2,3], then row+offset will find the witness values in a specific row
and then next function next trace mask is based on next interaction mask
data:image/s3,"s3://crabby-images/a60fa/a60fa0a1c4cf93eb87585f75b385a9b974029be3" alt=""
it would be go to the next column and the same row to read witness value.
then note3