-
Notifications
You must be signed in to change notification settings - Fork 198
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: Refactor R1CS shape to split the commitment key generation #315
Conversation
8402257
to
94e527b
Compare
} | ||
|
||
/// Computes the number of generators required for the commitment key corresponding to shape `S`. | ||
fn commitment_key_size<E: Engine>(S: &R1CSShape<E>, ck_floor: &CommitmentKeyHint<E>) -> usize { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Does it make sense to pass a vector/slice of R1CSShape objects to commitment_key
method and have it pick the right size? This will avoid having two methods and logic above this layer?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the clarification! I think we could still have commitment_key
to be a method inside R1CSShape rather than having two separate methods outside. For now, it takes (S: &R1CSShape, ck_floor: &CommitmentKeyHint) as arguments and returns a ck. In the future, it can take a collection of R1CSShape and hints and returns a ck.
In other words, I don't see what is gained from having two methods, one called commitment_key
and another called commitment_key_size
. Why not inline the contents of commitment_key_size
inside commitment_key
method and then move commitment_key
to be a method under R1CSShape
type rather than a stand-alone method?
TL;DR: splits off one major source of diff lines from PR microsoft#283. Inherently, there are many R1CS shapes to consider when tailoring public parameter creation to non-uniform step-circuits. However, the commitment key generation should only be done once for all circuits (once a suitable size has been determined by looking at all R1CS shapes). This splits the relevant Nova functions into `r1cs_shape_and_key`, `r1cs_shape` and `commitment_key` to enable the flexibility deamnded by the above model. In detail: - Renamed the `r1cs_shape` method across various files to `r1cs_shape_and_key`, indicating its functionality is to return both `R1CSShape` and `CommitmentKey`. - Altered function calls from `r1cs_shape` to `r1cs_shape_and_key` in files such as `direct.rs`, `nifs.rs`, `lib.rs` and `circuit.rs`, - Split the creation of `R1CSShape` and `CommitmentKey` into separate functions in the `NovaShape` object in `r1cs.rs` - Removed the `R1CS` struct in `mod.rs` as it only contained a phantom data, with related operations performed elsewhere. - Implemented changes to enhance code readability, including the addition of a new `commitment_key_size` function, and overall code reformatting for clarity.
e8c89d1
to
a4ead79
Compare
Since this PR is stale, closing it for now. Please reopen if you wish to contribute. |
This is a fragment of #283
TL;DR:
Splits off one major source of diff lines from PR #283. Inherently, there are many R1CS shapes to consider when tailoring public parameter creation to non-uniform step-circuits. However, the commitment key generation should only be done once for all circuits (once a suitable size has been determined by looking at all R1CS shapes). This splits the relevant Nova functions into
r1cs_shape_and_key
,r1cs_shape
andcommitment_key
to enable the flexibility deamnded by the above model.In detail:
r1cs_shape
method across various files tor1cs_shape_and_key
, indicating its functionality is to return bothR1CSShape
andCommitmentKey
.r1cs_shape
tor1cs_shape_and_key
in files such asdirect.rs
,nifs.rs
,lib.rs
andcircuit.rs
,R1CSShape
andCommitmentKey
into separate functions in theNovaShape
object inr1cs.rs
R1CS
struct inmod.rs
as it only contained a phantom data, with related operations performed elsewhere.commitment_key_size
function, and overall code reformatting for clarity.