You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The integer suffixes are expected for now, and are correct (safe) behaviour - the fault here lies in the line qc = qasm2.loads(...) in the function. As mentioned offline, neither rzx nor ecr are gate that are known to OpenQASM 2, and are not present in qelib1.inc, so the exporter must define them. On re-import, we cannot assume that a gate statement actually corresponds precisely to Qiskit's gate of the same name. It's doable for us to determine if an ecr definition matches, but not in general for us to determine if some specification of a parametric gate is compatible with Qiskit's version (and any magic inference like this is rather expensive from a performance perspective).
qasm2.LEGACY_CUSTOM_INSTRUCTIONS is explained in the documentation - it doesn't contain ecr or rzx (https://docs.quantum.ibm.com/api/qiskit/qasm2#legacy-compatibility) and won't be updated to include them because it's a backwards-compatibility object only. We don't currently have a data object available that supplies all of the Qiskit standard gates (see #10737), but you can easily add ecr and rzx to the list you're passing there, using CustomInstruction. Since this issue keeps being raised, here's explicitly how you do it:
The way to "fix" the integer suffixes so they don't appear by default is for us to define new library files that are specific to Qiskit. Then we won't have any of the problems of needing to make assumptions about arbitrary user input, because we supply the header files. We've got the design in #10737, but as I've mentioned before, we haven't had the time or priority to implement it yet.
Within the presence of the integer suffixes, there is a bug here on the second export (which I thought I'd fixed before) - the ordering of the gate statements in the second dump is somehow coming out out of order. I don't know precisely why that is right now, but I'll look into it, thanks.
Environment
What is happening?
Loading/exporting QASM2 code gives sometimes wrong operation names for gates like ECR or RZX, leading to errors like
or showing gate name patterns like
ecr_.*
orrzx_.*
when listing the operations available in the circuit.How can we reproduce the issue?
QASM2
What should happen?
Get the expected names for the different operations (
"ecr"
,"rzx"
, etc) instead of names like"rzx_4520860432_5206602512"
or"ecr_140645991950416"
Any suggestions?
No response
The text was updated successfully, but these errors were encountered: