tensorcircuit.translation¶
Circuit object translation in different packages
- tensorcircuit.translation.cirq2tc(qc: Any, n: int | None = None, inputs: List[float] | None = None, is_dm: bool = False, circuit_constructor: Any | None = None, circuit_params: Dict[str, Any] | None = None) Any[source]¶
Generate a tensorcircuit circuit from the cirq circuit.
- Parameters:
qc (cirq.Circuit) – A quantum circuit in cirq
n (Optional[int], optional) – # of qubits, defaults to None
inputs (Optional[List[float]], optional) – Input state of the circuit, defaults to None
is_dm (bool, optional) – whether to use DMCircuit, defaults to False
circuit_constructor (Any, optional) – _description_, defaults to None
circuit_params (Optional[Dict[str, Any]], optional) – _description_, defaults to None
- Returns:
_description_
- Return type:
Any
- tensorcircuit.translation.eqasm2tc(eqasm: str, nqubits: int | None = None, headers: Tuple[int, int] = (6, 1)) Circuit[source]¶
Translation qexe/eqasm instruction to tensorcircuit Circuit object
- Parameters:
eqasm (str) – _description_
nqubits (Optional[int], optional) – _description_, defaults to None
headers (Tuple[int, int], optional) – lines of ignored code at the head and the tail, defaults to (6, 1)
- Returns:
_description_
- Return type:
- tensorcircuit.translation.perm_matrix(n: int) Any[source]¶
Generate a permutation matrix P. Due to the different convention or qubits’ order in qiskit and tensorcircuit, the unitary represented by the same circuit is different. They are related by this permutation matrix P: P @ U_qiskit @ P = U_tc
- Parameters:
n (int) – # of qubits
- Returns:
The permutation matrix P
- Return type:
Tensor
- tensorcircuit.translation.qir2cirq(qir: List[Dict[str, Any]], n: int, extra_qir: List[Dict[str, Any]] | None = None) Any[source]¶
Generate a cirq circuit using the quantum intermediate representation (qir) in tensorcircuit.
- Example:
>>> c = tc.Circuit(2) >>> c.H(1) >>> c.X(1) >>> cisc = tc.translation.qir2cirq(c.to_qir(), 2) >>> print(cisc) 1: ───H───X───
- Parameters:
qir (List[Dict[str, Any]]) – The quantum intermediate representation of a circuit.
n (int) – # of qubits
extra_qir (Optional[List[Dict[str, Any]]]) – The extra quantum IR of tc circuit including measure and reset on hardware, defaults to None
- Returns:
qiskit cirq object
- Return type:
Any
#TODO(@erertertet): add default theta to iswap gate add more cirq built-in gate instead of customized add unitary test with tolerance add support of cirq built-in ControlledGate for multiplecontroll support more element in qir, e.g. barrier, measure…
- tensorcircuit.translation.qir2json(qir: List[Dict[str, Any]], simplified: bool = False) List[Dict[str, Any]][source]¶
transform qir to json compatible list of dict where array is replaced by real and imaginary list
- Parameters:
qir (List[Dict[str, Any]]) – _description_
simplified (bool) – If False, keep all info for each gate, defaults to be False. If True, suitable for IO since less information is required
- Returns:
_description_
- Return type:
List[Dict[str, Any]]
- tensorcircuit.translation.qir2qiskit(qir: List[Dict[str, Any]], n: int, extra_qir: List[Dict[str, Any]] | None = None, initialization: Any | None = None) Any[source]¶
Generate a qiskit quantum circuit using the quantum intermediate representation (qir) in tensorcircuit.
- Example:
>>> c = tc.Circuit(2) >>> c.H(1) >>> c.X(1) >>> qisc = tc.translation.qir2qiskit(c.to_qir(), 2) >>> qisc.data [(Instruction(name='h', num_qubits=1, num_clbits=0, params=[]), [Qubit(QuantumRegister(2, 'q'), 1)], []), (Instruction(name='x', num_qubits=1, num_clbits=0, params=[]), [Qubit(QuantumRegister(2, 'q'), 1)], [])]
- Parameters:
qir (List[Dict[str, Any]]) – The quantum intermediate representation of a circuit.
n (int) – # of qubits
extra_qir (Optional[List[Dict[str, Any]]]) – The extra quantum IR of tc circuit including measure and reset on hardware, defaults to None
initialization (Optional[Tensor]) – Circuit initial state in qiskit format
- Returns:
qiskit QuantumCircuit object
- Return type:
Any
- tensorcircuit.translation.qiskit2tc(qc: Any, n: int, inputs: List[float] | None = None, is_dm: bool = False, circuit_constructor: Any | None = None, circuit_params: Dict[str, Any] | None = None, binding_params: Sequence[float] | Dict[Any, float] | None = None) Any[source]¶
Generate a tensorcircuit circuit from the qiskit circuit.
- Example:
>>> qisc = QuantumCircuit(2) >>> qisc.h(0) >>> qisc.x(1) >>> qc = tc.translation.qiskit2tc(qisc, 2) >>> qc.to_qir()[0]['gatef']
- Parameters:
qc (QuantumCircuit) – A quantum circuit in qiskit.
n (int) – # of qubits
inputs (Optional[List[float]]) – Input state of the circuit. Default is None.
circuit_constructor –
Circuit,DMCircuitorMPSCircuitcircuit_params (Optional[Dict[str, Any]]) – kwargs given in Circuit.__init__ construction function, default to None.
binding_params (Optional[Union[Sequence[float], Dict[Any, float]]]) – (variational) parameters for the circuit. Could be either a sequence or dictionary depending on the type of parameters in the Qiskit circuit. For
ParameterVectorElementuse sequence. ForParameteruse dictionary.
- Returns:
A quantum circuit in tensorcircuit
- Return type:
Any
- tensorcircuit.translation.qiskit_from_qasm_str_ordered_measure(qasm_str: str) Any[source]¶
qiskit
from_qasm_strmethod cannot keep the order of measure as the qasm file, we provide this alternative function in case the order of measure instruction matters- Parameters:
qasm_str (str) – open qasm str
- Returns:
qiskit.circuit.QuantumCircuit- Return type:
Any