privacy-scaling-explorations/sonobe

More generalized API

mimoo opened this issue · 6 comments

Hello hello!

We over at noname (https://github.com/zksecurity/noname) are looking on how we could integrate with sonobe. We have our own R1CS serialization and witness generator in Rust, and are compatible with snarkjs in the sense that we can produce a .r1cs and .witness files that look like what circom produces.

We wanted to know if we could call sonobe like a library (we're in Rust too!), passing it either our R1CS format or the R1CS format that you use, and for the witness generator perhaps passing a closure with our own witness generator that produces a vec of bigint or something that you understand :o

That would be very cool!
The way that different circuit arithmetizations can be plugged in is through the FCircuit interface. I guess that one way to move it forward would be implementing it with noname logic for it, and then a FCircuit defined with noname can be plugged into sonobe and be folded and so on.
Does that sound like an approach that would make sense from noname's perspective?

mm I see, the problem is that we're not using arkworks, but maybe we could implement arkworks as a backend. It seems like it would be easier to just pass the Circom R1CS and be able to pass a closure for witness generation, which I believe we could do if you had a higher-level API than this. wdyt?

Hey David! I just wrote a prototype library to port noname R1CS circuits to arkworks. It now shouldn't be too hard to implement the FCircuit trait, which is what I'm going to do in the next few days.

oh this is great :) I think we could use this to prove/verify R1CS directly in noname using arkworks (zksecurity/noname#135)!

actually @dmpierre if you want to upstream this code we would accept a PR as well :o (up to you!)

Looking at how to upstream this, it looks like noname is using arkworks libraries at version 0.3. In our case, sonobe is using arkworks libraries at version 0.4. If I upstream this in the noname repo, there will be compatibility issues down the line. I will continue this work with a separate lib and continue the discussion on integrating this to noname in the PR you opened.

thanks so much! Created an issue for that here: zksecurity/noname#138 I believe it should be pretty straightforward for us to move to 0.4.0!