Skip to content
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

ZIR-236: Create a new Zirgen Standard Library #73

Open
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

jacobdweightman
Copy link
Contributor

[NOT URGENT FOR REVIEW]

It seems to me that there are four tiers of components, divided by importance and frequency of use:

  1. Built-ins: the core building blocks that can't be implemented in Zirgen itself (e.g. NondetReg)
  2. Preamble components: slight abstractions around built-ins that will almost certainly be used in every circuit (e.g. Reg)
  3. Standard components: components that are likely to be sufficiently useful across many circuits, but the user should "opt-in" (e.g. OneHot<N>, BitReg, etc)
  4. Everything else: circuit-specific things, "third party" component libraries, etc.

This PR takes a first pass at introducing a "standard library" for components of variety (3). The build system changes are minimal and this library isn't treated differently than others; the programmer still has to -I path/to/standard-library to use it. I leave that for future work, as it probably warrants discussions and possibly an RFC.

@github-actions github-actions bot changed the title Create a new Zirgen Standard Library ZIR-236: Create a new Zirgen Standard Library Nov 14, 2024
@@ -19,17 +18,6 @@ component BitReg(val: Val) {
reg
}

// Check that valid bits are valid
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what was the reasoning for moving the tests out of here into a separate file? Is there some technical reason that has to happen, or was it a style choice?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, good question! If the tests stay in the "main" library source, they get included into any importing module. This means they would be rerun when testing code that uses this library, and also clutter the test output. I think this is undesirable, so I extracted the tests to a separate file.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants