-
Notifications
You must be signed in to change notification settings - Fork 117
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
add stimcirq tags #862
add stimcirq tags #862
Conversation
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.
I can't accept this as currently designed.
The basic issue is you are hardcoding your particular usage of tags into the library (replace a gate based on a tag), rather than making a tool that other people would also use. Stim and stimcirq should attach as little semantic meaning to tags as possible; there should be no kind of replacement logic triggered by the presence of a tag. Instead, the conversion should attempt to preserve the tags while making as few changes as possible.
For example, when stimcirq is converting from a stim circuit to a cirq circuit, it could add the tags appearing on the stim instruction to the resulting cirq gates as a string or as a custom class stimcirq.StimTag
. Then, when converting from cirq to stim, it could look for stimcirq.CirqTag
tags and turn them into tags in the stim circuit. For handling more general cases (since cirq allows a wide variety of tagging), the user should be able to specify custom tag conversion functions that take a cirq tag and return a stim tag (or vice versa).
The use case here is not related to the tags in STIM. Instead, here I'm working on the cirq to stim conversion, when the cirq circuit has non-standard gates |
} | ||
""" | ||
REPEAT 3 { | ||
H 0 |
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.
Do a test where the stim circuit ends up containing a tag.
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.
@Strilanc this required some extra functionality (persisting cirq tags through to stim tags) beyond our use case here but I gave a stab at it. See my most recent commit for an example of what I'm thinking. I haven't run/written tests on it yet.
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.
@Strilanc , done, check my latest commit. Note that tags on cirq.CircuitOperation
's aren't persisted through - only tags associated with cirq.TaggedOperation
s are maintained
7906302
to
84d3e40
Compare
Obsoleted by #866 |
Note: resolved offline |
- Add `tag: str = ""` to `stim.Circuit.append` - Stim tags now become string tags on cirq circuit operations - A string tag on a cirq operation will turn into a stim tag by default if there is exactly one such string tag - Add optional `tag_func` argument to `stimcirq.cirq_circuit_to_stim_circuit` Some inspiration from #862
When a particular cirq operation has a tag, convert it to stim according to the tag's value.