following the first post 1
test command
RUST_LOG=stwo=trace cargo test --package powdr-pipeline --test pil --features stwo -- witness_lookup --exact --show-output>result.txt
Implementation notes
Witness to BaseColumn
witness needs to be transformed into BaseColumns and then use the combine function to get fraction.
in Plonk example, all the witness columns are built at the beginning as BaseColumn
data:image/s3,"s3://crabby-images/f5a57/f5a57c40f46ec9e86b37107806a70cc7301080a3" alt=""
BaseColumn is defined as:
data:image/s3,"s3://crabby-images/28277/28277a1136f818f193879209a3dcda0a7b35db62" alt=""
The values it contains, are PackedM31
How many columns that logup gen created?
checking the example of stwo repo plonk
The generate interation trace function in plonk use 2 times finalized_col, for two secure field columns?
data:image/s3,"s3://crabby-images/96040/960401ac82a2b014b24f9db16332439d0f43f025" alt=""
it gives 8 columns in logup trace, which means, my implementation might has problems here
data:image/s3,"s3://crabby-images/67c21/67c21bfcaab89a2f30ace0643357c4b716e48965" alt=""
investigation:
in the info evaluator, the implementation of EvalAtRow for InfoEvaluator has a logup macro, contains the logup related functions implementation.
data:image/s3,"s3://crabby-images/6c947/6c947e89df9a2ef8267c9716368324833d2fca49" alt=""
you can find the definition of logup_proxy! in EvalAtRow, the interesting thing here is, the offset_mask in InfoEvaluator, is empty, it moved to logup interaction?
The zip_eq problems cased by logup batching, now I don’t use batching
the first one is no batching, the second is batching in pairs
data:image/s3,"s3://crabby-images/ff31a/ff31a184d9fa9a4f67af4001c9e80676488b3955" alt=""
After a simple test pass, the most important tasks are:
- Add constraints for lookup identity in PowdrEval evaluate function, need to check the maximum numbers of the columns that are combined by random linear combination, to put in either left or right side of the logup
- gen_interaction_trace function
- provide the related witness columns to gen_interaction_trace function
gen_interaction_trace function
- the column need to be BaseColumn format, which means it should be bitreverse order, and in stwo base field.
- very often it needs columns from the constant columns, probably, should come from self.fixed. Even though accessing fixed columns again after setup sounds bit wrong, but setup should mainly save the time of interpolation, commitment. we need more cost in prove if we access fixed, but this should not be the bit cost compare to commit/interpolate it again.
check the maximum numbers of the columns that are combined by random linear combination, to put in either left or right side of the logup
ran riscv keccak test to see the number I should set
I put 50, since there is one in keccak test has 50
I found the pil has problem that the lookup is for bus, always has stage 1 witness, I need to learn more about the bus pil witgen, to ask for help and process further