-
Notifications
You must be signed in to change notification settings - Fork 220
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
Thin down stdlib to the minimum necessary and move code into external libraries. #1258
Comments
I think we should figure out a better way to do this because:
The last point is undesirable since it means that the stdlib can still grow over time based on the opcodes that ACIR introduces. The second point could probably be mitigated by pre-compiling the fallback functions and then once Noir has compiled ACIR, we then have a pass which replaces the opcodes which cannot be supported. A middle-ground would be to somehow only introduce the concept of fallbacks when you get to the SSA stage. In general, I'd like for us to not need to maintain any of these fallback functions and have the community be responsible for this. The only thing we maintain are simple functions which are useful for a range of context's and stable. One solution for moving these out is to allow users to override the fallbacks by maybe passing in --override-sha256 or give the user the ability to conditional compile in the Noir source code. |
Agreed, it's definitely suboptimal that adding new blackbox functions results in the stdlib growing. I don't think that we need to be concerned with precompiling fallback ACIR for this issue however. It's just an issue of communicating what code we insert in place of the bb function but that can happen either in the frontend or inside the ACVM compiler. If we we're going to fallback to functions which are implemented outside of the stdlib then it should be done by the user themselves rather than having a canonical fallback. Having a stdlib with a dependency tree is weird imo (why I favoured keeping them inside the stdlib) so having the user specify it themselves makes it explicit (along with the benefit of avoiding downloading a bunch of unnecessary dependencies). |
Yeah if it's done on the frontend then having the user do it explicitly is a good strategy. I like that method since it means we do absolutely nothing and the user can replace the black box function with whatever they choose; could even replace it with a function which does nothing. ^ A variant of this feature may be able to stand on it own merit. The advantage of having acvm do it, is that different frontends can use it and other functions placed in acvm-stdlib, and there will be one place where we do fallbacks |
Relatedly, I've been profiling the parser a little, and the inclusion of |
Note that we've removed the concept of fallback functions so we can push forward on this a little more easily. |
Problem
With various grant projects we've set the final step as "acceptance into the Noir standard library", this is problematic for a couple of reasons:
Proposed solution
We should restrict the usage of the stdlib to only be the most common of functions and functions which are required to be in the stdlib (e.g. black box function definitions). Everything else should be spun out into libraries which have their own separate versioning.
merkle.nr
can be spun out intonoir-lang/merkle
(I've pushed an initial version of this to https://github.com/TomAFrench/noir-merkle which can be transferred to the org),sha256.nr
sha512.nr
,hash/poseidon.nr
should be broken out into anoir-lang/hashes
monorepo similar to https://github.com/RustCrypto/hashes.sha256
. These fallback implementations would have to stay inside the standard library imo.ec.nr
can spun out intonoir-lang/elliptic-curves
.Pushing out these functions from the stdlib forces us to deal with remote dependencies much more than when everything is in the stdlib. This is a good opportunity for dogfooding and allows us to strengthen our integration tests.
Alternatives considered
We can retain these functions in the standard library and have it grow over time (continuously?). This will likely be a backwards compatibility nightmare in future.
Additional context
No response
Submission Checklist
Tasks
ec
module of stdlib and create external library #4857merkle
module in stdlib and create external library #4858The text was updated successfully, but these errors were encountered: