Fix wrapping of ``GroverOperator`` (#6697)

* barrier isn't good enough to check!

* add test

Co-authored-by: Manoel Marques <Manoel.Marques@ibm.com>
This commit is contained in:
Julien Gacon 2021-07-08 05:14:51 +02:00 committed by GitHub
parent d83ce486b4
commit ecde4971de
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 19 additions and 3 deletions

View File

@ -15,6 +15,7 @@
from typing import List, Optional, Union
import numpy
from qiskit.circuit import QuantumCircuit, QuantumRegister, AncillaRegister
from qiskit.exceptions import QiskitError
from qiskit.quantum_info import Statevector, Operator, DensityMatrix
from .standard_gates import MCXGate
@ -274,10 +275,10 @@ class GroverOperator(QuantumCircuit):
circuit.global_phase = numpy.pi
self.add_register(*circuit.qregs)
if self._insert_barriers:
circuit_wrapped = circuit.to_instruction()
else:
try:
circuit_wrapped = circuit.to_gate()
except QiskitError:
circuit_wrapped = circuit.to_instruction()
self.compose(circuit_wrapped, qubits=self.qubits, inplace=True)

View File

@ -69,6 +69,21 @@ class TestGroverOperator(QiskitTestCase):
grover_op, oracle=np.diag((-1) ** mark.data), zero_reflection=diffuse.data
)
def test_stateprep_contains_instruction(self):
"""Test wrapping works if the state preparation is not unitary."""
oracle = QuantumCircuit(1)
oracle.z(0)
instr = QuantumCircuit(1)
instr.s(0)
instr = instr.to_instruction()
stateprep = QuantumCircuit(1)
stateprep.append(instr, [0])
grover_op = GroverOperator(oracle, stateprep)
self.assertEqual(grover_op.num_qubits, 1)
def test_reflection_qubits(self):
"""Test setting idle qubits doesn't apply any operations on these qubits."""
oracle = QuantumCircuit(4)