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

Feature Request : Circuit Compose #453

Open
ananthakrishnagopal opened this issue Aug 13, 2024 · 1 comment
Open

Feature Request : Circuit Compose #453

ananthakrishnagopal opened this issue Aug 13, 2024 · 1 comment

Comments

@ananthakrishnagopal
Copy link

It would be nice to be able to build composable circuits, like how one can use qiskit.append/qiskit.compose.

@TysonRayJones
Copy link
Member

Hi Ananthakrishna,

QuEST is an imperative simulator; it does exactly what you tell it, step by step. Having a circuit type would indeed be convenient, but we've so far decided this is not worthwhile at the level of QuEST where we are restricted to a C-compatible interface. Unless we can abstract it very well using C++, the necessary C memory management to maintain and modify circuits would be nightmarish.

Instead, we have let downstream projects like QuESTlink and pyQuEST define their own circuit structures natural to their language. For example, QuESTlink uses a list of Mathematica symbols and pyQuEST uses a list of Python objects.

As such, we've so far agreed there is a very small need for a usable user-facing circuit structure at the C level. There is an additional case to be made that such a structure would allow us to do all sorts of additional circuit-wide optimisations to massively speedup subsequent simulation. That would still however mean we must develop a circuit optimiser/compiler in C++, whereas such inexpensive, high-level logic is better suited to high-level languages like Python (indeed, QuESTlink already has such a compiler). We could instead integrate an existing C++ compiler like tket, although this breaks our design rule of "use few, if any, external dependencies".

It remains an interesting idea to optionally integrate with tket, which is incidentally something we recently discussed! Alas, I'm doubtful it will come soon, and certainly cannot be fit into our backlog for our mid-September QuEST v4 release.

I'll keep this issue open to inspire more discussion, and report back to if our plans develop!

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

No branches or pull requests

2 participants