當前位置: 首頁>>代碼示例>>Python>>正文


Python gates.H屬性代碼示例

本文整理匯總了Python中pyquil.gates.H屬性的典型用法代碼示例。如果您正苦於以下問題:Python gates.H屬性的具體用法?Python gates.H怎麽用?Python gates.H使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在pyquil.gates的用法示例。


在下文中一共展示了gates.H屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: oracle_grover

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def oracle_grover(oracle: Program, qubits: List[int], num_iter: int = None) -> Program:
        """
        Implementation of Grover's Algorithm for a given oracle.

        :param oracle: An oracle defined as a Program. It should send :math:`\ket{x}`
            to :math:`(-1)^{f(x)}\ket{x}`, where the range of f is {0, 1}.
        :param qubits: List of qubits for Grover's Algorithm.
        :param num_iter: The number of iterations to repeat the algorithm for.
                         The default is the integer closest to :math:`\frac{\pi}{4}\sqrt{N}`,
                         where :math:`N` is the size of the domain.
        :return: A program corresponding to the desired instance of Grover's Algorithm.
        """
        if num_iter is None:
            num_iter = int(round(np.pi * 2 ** (len(qubits) / 2.0 - 2.0)))
        uniform_superimposer = Program().inst([H(qubit) for qubit in qubits])
        amp_prog = amplification_circuit(uniform_superimposer, oracle, qubits, num_iter)
        return amp_prog 
開發者ID:rigetti,項目名稱:grove,代碼行數:19,代碼來源:grover.py

示例2: _core_qft

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def _core_qft(qubits: List[int], coeff: int) -> Program:
    """
    Generates the core program to perform the quantum Fourier transform
    
    :param qubits: A list of qubit indexes.
    :param coeff: A modifier for the angle used in rotations (-1 for inverse QFT, 1 for QFT)
    :return: A Quil program to compute the core (inverse) QFT of the qubits.
    """
    
    q = qubits[0]
    qs = qubits[1:]
    if 1 == len(qubits):
        return [H(q)]
    else:
        n = 1 + len(qs)
        cR = []
        for idx, i in enumerate(range(n - 1, 0, -1)):
            q_idx = qs[idx]
            angle = math.pi / 2 ** (n - i)
            cR.append(CPHASE(coeff * angle, q, q_idx))
        return _core_qft(qs, coeff) + list(reversed(cR)) + [H(q)] 
開發者ID:rigetti,項目名稱:grove,代碼行數:23,代碼來源:fourier.py

示例3: _create_bv_circuit

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def _create_bv_circuit(self, bit_map: Dict[str, str]) -> Program:
        """
        Implementation of the Bernstein-Vazirani Algorithm.

        Given a list of input qubits and an ancilla bit, all initially in the
        :math:`\\vert 0\\rangle` state, create a program that can find :math:`\\vec{a}` with one
        query to the given oracle.

        :param Dict[String, String] bit_map: truth-table of a function for Bernstein-Vazirani with
            the keys being all possible bit vectors strings and the values being the function values
        :rtype: Program
        """
        unitary, _ = self._compute_unitary_oracle_matrix(bit_map)
        full_bv_circuit = Program()

        full_bv_circuit.defgate("BV-ORACLE", unitary)

        # Put ancilla bit into minus state
        full_bv_circuit.inst(X(self.ancilla), H(self.ancilla))

        full_bv_circuit.inst([H(i) for i in self.computational_qubits])
        full_bv_circuit.inst(
            tuple(["BV-ORACLE"] + sorted(self.computational_qubits + [self.ancilla], reverse=True)))
        full_bv_circuit.inst([H(i) for i in self.computational_qubits])
        return full_bv_circuit 
開發者ID:rigetti,項目名稱:grove,代碼行數:27,代碼來源:bernstein_vazirani.py

示例4: test_diffusion_operator

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_diffusion_operator():
    """
    Checks that the diffusion operator outputs the correct operation
    """
    created = decomposed_diffusion_program(qubits[:2])
    desired = Program()
    for def_gate in created.defined_gates:
        desired.defgate(def_gate.name, def_gate.matrix)
    qubit0 = qubits[0]
    qubit1 = qubits[1]
    desired.inst(X(qubit0))
    desired.inst(X(qubit1))
    desired.inst(H(qubit1))
    desired.inst(RZ(-np.pi, qubit0))
    desired.inst(CNOT(qubit0, qubit1))
    desired.inst(RZ(-np.pi, qubit0))
    desired.inst(H(qubit1))
    desired.inst(X(qubit0))
    desired.inst(X(qubit1))
    assert desired == created 
開發者ID:rigetti,項目名稱:grove,代碼行數:22,代碼來源:test_amplification.py

示例5: test_x_oracle_two_grover

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_x_oracle_two_grover(x_oracle):
    """Testing that Grover's algorithm with an oracle that applies an X gate to the query bit works,
     with two iterations."""
    qubits = [0]
    oracle, _ = x_oracle
    generated_x_oracle_grover = Grover().oracle_grover(oracle, qubits, num_iter=2)
    # First we put the input into uniform superposition.
    gates = [H]
    for _ in range(2):
        # Now an oracle is applied.
        gates.append(X)
        # We apply the diffusion operator.
        gates.append(H)
        gates.append(HADAMARD_DIFFUSION_LABEL)
        gates.append(H)
    check_instructions(gates, generated_x_oracle_grover) 
開發者ID:rigetti,項目名稱:grove,代碼行數:18,代碼來源:test_grover.py

示例6: test_gradient_program

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_gradient_program():
    f_h = 0.25
    precision = 2
    
    trial_prog = gradient_program(f_h, precision)
    
    result_prog = Program([H(0), H(1)])

    phase_factor = np.exp(1.0j * 2 * np.pi * abs(f_h))
    U = np.array([[phase_factor, 0],
                  [0, phase_factor]])
    q_out = range(precision, precision+1)
    for i in range(precision):
        if i > 0:
            U = np.dot(U, U)
        cU = controlled(U)
        name = "CONTROLLED-U{0}".format(2 ** i)
        result_prog.defgate(name, cU)
        result_prog.inst((name, i) + tuple(q_out))

    result_prog.inst([SWAP(0, 1), H(0), CPHASE(-1.5707963267948966, 0, 1),
                      H(1), MEASURE(0, 0), MEASURE(1, 1)])

    assert(trial_prog == result_prog) 
開發者ID:rigetti,項目名稱:grove,代碼行數:26,代碼來源:test_jordan_gradient.py

示例7: test_run_swap

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_run_swap():
    """
    Test the qvm return piece
    """
    expected_bitstring = [1, 1, 1, 0, 0, 0, 0, 0, 0]
    prog_a = Program().inst(H(0))
    prog_b = Program().inst(H(1))
    with patch("pyquil.api.QuantumComputer") as qc:
        qc.run.return_value = expected_bitstring
        test_overlap = run_swap_test(prog_a, prog_b,
                                     number_of_measurements=5,
                                     quantum_resource=qc)

        assert np.isclose(np.sqrt(1 - 2 * np.mean(expected_bitstring)),
                          test_overlap)

    expected_bitstring = [1, 1, 1, 0, 1]
    prog_a = Program().inst(H(0))
    prog_b = Program().inst(H(1))
    with patch("pyquil.api.QuantumComputer") as qc:
        qc.run.return_value = expected_bitstring
        with pytest.raises(ValueError):
            test_overlap = run_swap_test(prog_a, prog_b,
                                         number_of_measurements=5,
                                         quantum_resource=qc) 
開發者ID:rigetti,項目名稱:grove,代碼行數:27,代碼來源:test_swap.py

示例8: test_tensor_gates_single_qubit

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_tensor_gates_single_qubit():
    prog = Program().inst([Hgate(0)])
    test_unitary = tensor_gates(gate_matrix, {}, prog.instructions[0], 1).toarray()
    true_unitary = gate_matrix['H']
    assert np.allclose(test_unitary, true_unitary)

    prog = Program().inst([Hgate(0)])
    test_unitary = tensor_gates(gate_matrix, {}, prog.instructions[0], 5).toarray()
    true_unitary = np.kron(np.eye(2**4), gate_matrix['H'])
    assert np.allclose(test_unitary, true_unitary)

    prog = Program().inst([RXgate(0.2, 3)])
    test_unitary = tensor_gates(gate_matrix, {}, prog.instructions[0], 5).toarray()
    true_unitary = np.kron(np.eye(2**1), np.kron(gate_matrix['RX'](0.2),  np.eye(2**3)))
    assert np.allclose(test_unitary, true_unitary)

    prog = Program().inst([RXgate(0.5, 4)])
    test_unitary = tensor_gates(gate_matrix, {}, prog.instructions[0], 5).toarray()
    true_unitary = np.kron(np.eye(2**0), np.kron(gate_matrix['RX'](0.5),  np.eye(2**4)))
    assert np.allclose(test_unitary, true_unitary) 
開發者ID:rigetti,項目名稱:reference-qvm,代碼行數:22,代碼來源:test_unitary_generator.py

示例9: test_simulation_phase

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_simulation_phase():
    """
    Test if the Phase gate is applied correctly to the tableau

    S|0> = |0>

    S|+> = |R>
    """
    prog = Program().inst(S(0))
    qvmstab = QVM_Stabilizer(num_qubits=1)
    qvmstab._apply_phase(prog.instructions[0])
    true_stab = np.array([[1, 1, 0],
                          [0, 1, 0]])
    assert np.allclose(true_stab, qvmstab.tableau)

    prog = Program().inst([H(0), S(0)])
    qvmstab = QVM_Stabilizer(num_qubits=1)
    qvmstab._apply_hadamard(prog.instructions[0])
    qvmstab._apply_phase(prog.instructions[1])
    true_stab = np.array([[0, 1, 0],
                          [1, 1, 0]])
    assert np.allclose(true_stab, qvmstab.tableau) 
開發者ID:rigetti,項目名稱:reference-qvm,代碼行數:24,代碼來源:test_stabilizer_qvm.py

示例10: test_parameter_not_given_error

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_parameter_not_given_error(self):
        """Test that the correct error is raised if a parameter is not given."""
        program = pyquil.Program()

        alpha = program.declare("alpha", "REAL")
        beta = program.declare("beta", "REAL")

        program += g.H(0)
        program += g.CNOT(0, 1)
        program += g.RX(alpha, 1)
        program += g.RZ(beta, 1)

        a = 0.1

        parameter_map = {"alpha": a}

        with pytest.raises(
            qml.DeviceError,
            match="The PyQuil program defines a variable .* that is not present in the given variable map",
        ):
            load_program(program)(wires=range(2), parameter_map=parameter_map) 
開發者ID:rigetti,項目名稱:pennylane-forest,代碼行數:23,代碼來源:test_converter.py

示例11: test_lifted_gate_single_qubit

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_lifted_gate_single_qubit():
    test_unitary = lifted_gate(H(0), 1)
    true_unitary = mat.H
    assert np.allclose(test_unitary, true_unitary)

    test_unitary = lifted_gate(H(0), 5)
    true_unitary = np.kron(np.eye(2 ** 4), mat.H)
    assert np.allclose(test_unitary, true_unitary)

    test_unitary = lifted_gate(RX(0.2, 3), 5)
    true_unitary = np.kron(np.eye(2 ** 1), np.kron(mat.RX(0.2), np.eye(2 ** 3)))
    assert np.allclose(test_unitary, true_unitary)

    test_unitary = lifted_gate(RX(0.5, 4), 5)
    true_unitary = np.kron(np.eye(2 ** 0), np.kron(mat.RX(0.5), np.eye(2 ** 4)))
    assert np.allclose(test_unitary, true_unitary) 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:18,代碼來源:test_tools.py

示例12: test_qc_calibration_1q

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_qc_calibration_1q(forest):
    # noise model with 95% symmetrized readout fidelity per qubit
    noise_model = asymmetric_ro_model([0], 0.945, 0.955)
    qc = get_qc("1q-qvm")
    qc.qam.noise_model = noise_model

    # bell state program (doesn't matter)
    p = Program()
    p += RESET()
    p += H(0)
    p += CNOT(0, 1)
    p.wrap_in_numshots_loop(10000)

    # Z experiment
    sz = ExperimentSetting(in_state=sZ(0), out_operator=sZ(0))
    e = Experiment(settings=[sz], program=p)

    results = qc.calibrate(e)

    # Z expectation value should just be 1 - 2 * readout_error
    np.isclose(results[0].expectation, 0.9, atol=0.01)
    assert results[0].total_counts == 20000 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:24,代碼來源:test_quantum_computer.py

示例13: test_qc_calibration_2q

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_qc_calibration_2q(forest):
    # noise model with 95% symmetrized readout fidelity per qubit
    noise_model = asymmetric_ro_model([0, 1], 0.945, 0.955)
    qc = get_qc("2q-qvm")
    qc.qam.noise_model = noise_model

    # bell state program (doesn't matter)
    p = Program()
    p += RESET()
    p += H(0)
    p += CNOT(0, 1)
    p.wrap_in_numshots_loop(10000)

    # ZZ experiment
    sz = ExperimentSetting(in_state=sZ(0) * sZ(1), out_operator=sZ(0) * sZ(1))
    e = Experiment(settings=[sz], program=p)

    results = qc.calibrate(e)

    # ZZ expectation should just be (1 - 2 * readout_error_q0) * (1 - 2 * readout_error_q1)
    np.isclose(results[0].expectation, 0.81, atol=0.01)
    assert results[0].total_counts == 40000 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:24,代碼來源:test_quantum_computer.py

示例14: test_sync_run_and_measure_mock

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_sync_run_and_measure_mock(qvm: QVMConnection):
    mock_qvm = qvm
    mock_endpoint = mock_qvm.sync_endpoint

    def mock_response(request, context):
        assert json.loads(request.text) == {
            "type": "multishot-measure",
            "qubits": [0, 1],
            "trials": 2,
            "compiled-quil": "H 0\nCNOT 0 1\n",
            "rng-seed": 52,
        }
        return "[[0,0],[1,1]]"

    with requests_mock.Mocker() as m:
        m.post(mock_endpoint + "/qvm", text=mock_response)
        assert mock_qvm.run_and_measure(BELL_STATE, [0, 1], trials=2) == [[0, 0], [1, 1]]

    with pytest.raises(ValueError):
        mock_qvm.run_and_measure(EMPTY_PROGRAM, [0]) 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:22,代碼來源:test_api.py

示例15: test_run

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import H [as 別名]
def test_run(forest):
    device = NxDevice(nx.complete_graph(3))
    qc = QuantumComputer(
        name="testy!",
        qam=QVM(connection=forest, gate_noise=[0.01] * 3),
        device=device,
        compiler=DummyCompiler(),
    )
    bitstrings = qc.run(
        Program(
            Declare("ro", "BIT", 3),
            H(0),
            CNOT(0, 1),
            CNOT(1, 2),
            MEASURE(0, MemoryReference("ro", 0)),
            MEASURE(1, MemoryReference("ro", 1)),
            MEASURE(2, MemoryReference("ro", 2)),
        ).wrap_in_numshots_loop(1000)
    )

    assert bitstrings.shape == (1000, 3)
    parity = np.sum(bitstrings, axis=1) % 3
    assert 0 < np.mean(parity) < 0.15 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:25,代碼來源:test_quantum_computer.py


注:本文中的pyquil.gates.H屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。