-
Notifications
You must be signed in to change notification settings - Fork 1k
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
Consolidate quantum state representations in cirq #4582
Comments
One question this raises is to what extent we wish to use mypy and to what extent runtime checks to see whether a given state belongs to one of the sets of quantum states listed earlier (e.g. is pure, is separable, etc) . I suspect that fully committing to the use of type system would lead to very complicated type relationships. Partially committing to it would lead to a situation where some of the checks would be done by mypy and others at runtime. On the other hand, having all such checks done at runtime is a uniform and easily extensible approach. |
(The classes we have for product and general quantum states demonstrate the temptation (encouraged by OOP-inspired programming languages) to build taxonomies. The reason taxonomies lead to clunky code is that the most appropriate classification of our objects is generally a local concern at the place of use. Using a type system (via user-defined classes) to force a particular taxonomy globally on the codebase leads to the use of a classification that is a poor fit in at least some of it. A nice alternative to a globally imposed taxonomy is provided by pattern matching wherein each place of use can choose a property to look at for classification at that location. For example, code computing fidelity could classify states by whether they are pure or mixed (to improve performance in the former case) and code checking separability could look at the number of qubits (to exploit the sufficiency of the PPT criterion for two qubits). The good news is that pattern matching is coming to python in version 3.10, see PEP 636. Perhaps we should keep that in mind when considering how to represent quantum states in cirq.) |
Tl;Dr - We should think about this and consider adding to the roadmap / have a propose a design. |
(Re-added kind/design-issue label since a "kind" label is required and this does seem like the most appropriate, at least until we agree on enough detail about how to proceed to change it to kind/roadmap-item.) |
I'd like to do this, but whatever we do I'd like to make it compatible for use in the simulator framework. What "level" are you most interested in here?
Whichever we choose, I agree with @tanujkhattar that a union will be hard to maintain, and a type hierarchy would be preferred. To integrate these into simulation, the base "interface" would need to support (params depending on which layer we're at):
Which I think is a good baseline for any quantum state representation to start from. The last three are a required part of the "interface", though it's fine if they throw NotImplemented; the simulator framework can work around that. |
FWIW my preference is (2) above. I think (1) is great but probably higher level than what's useful from a QIS standpoint. (3) is nice in that it avoids bringing in the notion of a "gate", which is a cirq.ops thing, into qis. But the downside of (3) is that the "whatever" in the "apply_whatever" function is different for every subtype, so that wouldn't be part of the base type, and thus just leaves a bunch of combinators in the base interface, severely limiting the usefulness of the abstraction. So I like (2) in that it's low-level, but useful as an abstraction. I think this could be extremely useful in combination with #4632, where we could have these classes be generic on the types of gates they support in For stabilizers we would need to rework those protocols a bit first. Right now the only way to apply a stabilizer effect is via The other thing that we'd have to do in order for this to be used in simulators, is to make sure all non-gate operations implement act_on. Right now the only missing one I see (outside of artificial tests) is PauliStringPhasor. Edit: ...And actually the thing that occurred to me later is that this change would also break any third-party users that are implementing operations without gates, which maybe is nobody, or maybe is a huge breaking change. (I believe we could come up with a deprecation path, however it could be a painful one if users have dozens of gateless operation classes). That said, I still think this is the correct design for a low-level abstraction around quantum state regardless of whether we can use it in simulators. We just wouldn't be able to use it in simulators if it's considered too big of a change, which is a bummer, but shouldn't block the feature in its own right. |
I tried this and (2) ends up being not particularly clean. The reason is that state vector simulator records which mixture option was chosen. This means At that point we're passing in so many args from |
Option (3) that I mentioned two comments above is done as of #5065. That PR created an interface
Implementations are expected to be bare bones. The interface operates on indices, not qubits. A prng must be explicitly passed in where needed. Implementations don't contain their own prng. There's also no notion of classical data here. It's just the raw data required to represent the state. This has implementations
It has the following interface:
Notably it doesn't have any abstract Anyway, perhaps all that's left for this issue is
|
After thinking about this for a bit, I believe the root problem is not going to be solved by a new quantum state representation (though the representation I added worked great for simulators), I think the core issue is that there are always going to be multiple incompatible ways to represent quantum states. We'll have some that are useful in simulators, some that are useful in low-level code, some that are useful in analysis, some that come from third parties, etc., and they may have no relationship to each other. If we want to support them all, then the What I'd propose here is that we get rid of This allows us to get rid of all the mandatory This also allows us to instrument a wider range of things as state-vector-like, just by adding the |
Is your design idea/issue related to a use case or problem? Please describe.
There is a zoo of quantum states and special representations they admit:
int
),In various places in cirq we have the need to represent states in some of the sets above (e.g. mixed states in
cirq.DensityMatrixSimulator
and MPS states incirq.contrib.quimb.mps_simulator
).A while back we discussed the question whether we should have a class to encapsulate a generic quantum state to hide the zoo behind a consistent interface. We decided not to do that and instead allow quantum states to be specified by simple primitive and numpy types (
int
,np.ndarray
). This made sense at the time since most code manipulating quantum states was particular to the specific use-case and given a small subset of the zoo that we needed to support it was easy to infer the nature of the state based on the type and shape information. We also defined a union typecirq.STATE_VECTOR_LIKE
to describe the subset of the zoo we found relevant to us. This consisted of only four cases.By now, we have added a class
cirq.ProductState
tocirq.STATE_VECTOR_LIKE
and also added another union typecirq.QUANTUM_STATE_LIKE
which encompassescirq.STATE_VECTOR_LIKE
and some additional options including another class for representing quantum states calledcirq.QuantumState
. We also have a mixin calledcirq.StateVectorMixin
...In summary, we had considered a choice between a lightweight class-free approach of a simple union whose members were either primitive or maintained elsewhere (numpy) and a more heavy-weight approach with a single class to encapsulate the zoo. We ended up with the worst of both worlds :-) We now have two union types each with a class encapsulating a subset of the states. This means that on one hand code handling quantum states needs to deal with the diversity of the zoo and we lack a common place to extend quantum states with new functionality and on the other hand we have three classes to maintain.
Describe your design idea/issue
Perhaps, it is time to re-evaluate. One approach merges
cirq.ProductState
,cirq.QuantumState
andcirq.StateVectorMixin
and addscirq.state(...)
which can take as arguments any of the present members of the two union types. For example, we could say things like thisThe factory
cirq.state
would continue to allow us to use simple ways to specify quantum states such as specifying computational basis states using anint
while also providing us with a single place to add general state-related functionality. In particular, the new class would be a natural place for code thatFiling to start discussion. Context: #3517.
The text was updated successfully, but these errors were encountered: