Powdr side:
run test in pipeline (I changed the test so it can include stwo):
#[test]
fn witness_lookup() {
let f = "pil/witness_lookup.pil";
let inputs = [3, 5, 2, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7]
.into_iter()
.map(GoldilocksField::from)
.collect::<Vec<_>>();
let pipeline = make_prepared_pipeline(f, inputs, Default::default(), LinkerMode::Bus);
test_mock_backend(pipeline);
let inputs = [3, 5, 2, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7]
.into_iter()
.map(Mersenne31Field::from)
.collect::<Vec<_>>();
let pipeline = make_prepared_pipeline(f, inputs, Default::default(), LinkerMode::Bus);
test_stwo_pipeline(pipeline);
}
the witness_lookup.pil file:
let N: int = 16;
namespace std::convert(N);
let fe = [];
namespace std::prover(N);
enum Query {
Input(int, int),
}
namespace Quad(N);
col fixed id(i) { i };
col fixed double(i) { i * 2 };
col witness input(i) query std::prelude::Query::Input(0, i + 1);
col witness wdouble;
col witness quadruple;
[input, wdouble] in [id, double];
[wdouble, quadruple] in [id, double];
public out = quadruple(N-1);
the first lookup identity looks like
left expression:
data:image/s3,"s3://crabby-images/415ab/415abc9f17a0ca8e84a057636348c77b4e237c4b" alt=""
right expression:
data:image/s3,"s3://crabby-images/614fe/614febbabfaef3ff3b978e3d36a534435acc55ad" alt=""
These are the polynomials should be built into logup.
Stwo side, some basics
Lookup elements in constraint_framework, logup.rs:
data:image/s3,"s3://crabby-images/40574/40574d5ce71b808c817b92b02217d598ba23b226" alt=""
The core function to understand is this
data:image/s3,"s3://crabby-images/2c9ef/2c9ef8769c6f3b61c974b8d9542682103b383692" alt=""
\(\alpha\) is for linear combination, so it can check several tables at the same time, \(z\) is the challenge for the logup. (needs a concrete example to confirm this)
attention: it takes a generic parameter N, which defines the degree of alpha_powers.
and when create a new lookupement, using relation macro like this:
data:image/s3,"s3://crabby-images/d482c/d482cbb2399d63e38147a099bb165c951a57df24" alt=""
to get PlonkLookupElements defined like this
data:image/s3,"s3://crabby-images/cde2a/cde2ae5ebb29681df402f36408d9bc177be0d7c6" alt=""
Summary the steps for implementing Logup:
- add lookupElement in PowdrEval, as when creating constraint by “add to relation”, one parameter is self.lookup_elements
data:image/s3,"s3://crabby-images/9ced0/9ced0980d130b1c9f18acd8d4e202b74fd29587f" alt=""
interesting, lookupElement is created by draw:
data:image/s3,"s3://crabby-images/4bfdd/4bfdd7e632cfc932b3406b26011aac91cd13c4fa" alt=""
- add constraint by add to relation
- Initiate PowdrEval with lookupElement
- generate logup trace, in stwo, namely the interaction trace