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


Python gates.RZ屬性代碼示例

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


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

示例1: test_diffusion_operator

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [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

示例2: test_psiref_bar_p2

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_psiref_bar_p2():
    bar = [(0, 1)]
    p = 2
    with patch('pyquil.api.get_qc', spec=qc_mod):
        inst = maxcut_qaoa(bar, steps=p)

    param_prog = inst.get_parameterized_program()

    # returns are the rotations correct?
    prog = param_prog([1.2, 3.4, 2.1, 4.5])
    result_prog = Program().inst([H(0), H(1),
                                  CNOT(0, 1), RZ(2.1, 1), CNOT(0, 1),
                                  X(0), PHASE(1.05, 0), X(0), PHASE(1.05, 0),
                                  H(0), RZ(-2.4, 0), H(0),
                                  H(1), RZ(-2.4, 1), H(1),
                                  CNOT(0, 1), RZ(4.5, 1), CNOT(0, 1),
                                  X(0), PHASE(2.25, 0), X(0), PHASE(2.25, 0),
                                  H(0), RZ(-6.8, 0), H(0),
                                  H(1), RZ(-6.8, 1), H(1),
                                  ])
    assert prog == result_prog 
開發者ID:rigetti,項目名稱:grove,代碼行數:23,代碼來源:test_maxcut.py

示例3: test_parameter_not_given_error

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [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

示例4: _one_q_sic_prep

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def _one_q_sic_prep(index: int, qubit: QubitDesignator) -> Program:
    """Prepare the index-th SIC basis state."""
    if index == 0:
        return Program()

    theta = 2 * np.arccos(1 / np.sqrt(3))
    zx_plane_rotation = Program([RX(-pi / 2, qubit), RZ(theta - pi, qubit), RX(-pi / 2, qubit)])

    if index == 1:
        return zx_plane_rotation

    elif index == 2:
        return zx_plane_rotation + RZ(-2 * pi / 3, qubit)

    elif index == 3:
        return zx_plane_rotation + RZ(2 * pi / 3, qubit)

    raise ValueError(f"Bad SIC index: {index}") 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:20,代碼來源:operator_estimation.py

示例5: _random_2q_programs

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def _random_2q_programs(n_progs=3):
    """Generate random programs that consist of single qubit rotations, a CZ, and single
    qubit rotations.
    """
    r = random.Random(52)

    def RI(qubit, angle):
        # throw away angle so we can randomly choose the identity
        return I(qubit)

    def _random_1q_gate(qubit):
        return r.choice([RI, RX, RY, RZ])(qubit=qubit, angle=r.uniform(0, 2 * pi))

    for _ in range(n_progs):
        prog = Program()
        prog += _random_1q_gate(0)
        prog += _random_1q_gate(1)
        prog += CZ(0, 1)
        prog += _random_1q_gate(0)
        prog += _random_1q_gate(1)
        yield prog 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:23,代碼來源:test_operator_estimation.py

示例6: test_exponentiate_bp0_ZY

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_exponentiate_bp0_ZY():
    # testing change of basis position 0
    q = QubitPlaceholder.register(8)
    generator = PauliTerm("Y", q[0], 1.0) * PauliTerm("Z", q[1], 1.0)
    para_prog = exponential_map(generator)
    prog = para_prog(1)
    result_prog = Program().inst(
        [
            RX(math.pi / 2.0, q[0]),
            CNOT(q[0], q[1]),
            RZ(2.0, q[1]),
            CNOT(q[0], q[1]),
            RX(-math.pi / 2, q[0]),
        ]
    )
    assert address_qubits(prog) == address_qubits(result_prog) 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:18,代碼來源:test_paulis_with_placeholders.py

示例7: test_exponentiate_bp1_YZ

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_exponentiate_bp1_YZ():
    q = QubitPlaceholder.register(8)
    # testing change of basis position 1
    generator = PauliTerm("Z", q[0], 1.0) * PauliTerm("Y", q[1], 1.0)
    para_prog = exponential_map(generator)
    prog = para_prog(1)
    result_prog = Program().inst(
        [
            RX(math.pi / 2.0, q[1]),
            CNOT(q[0], q[1]),
            RZ(2.0, q[1]),
            CNOT(q[0], q[1]),
            RX(-math.pi / 2.0, q[1]),
        ]
    )
    assert address_qubits(prog) == address_qubits(result_prog) 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:18,代碼來源:test_paulis_with_placeholders.py

示例8: test_exponentiate_3cob

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_exponentiate_3cob():
    # testing circuit for 3-terms with change of basis
    q = QubitPlaceholder.register(8)
    generator = PauliTerm("Z", q[0], 1.0) * PauliTerm("Y", q[1], 1.0) * PauliTerm("X", q[2], 1.0)
    para_prog = exponential_map(generator)
    prog = para_prog(1)
    result_prog = Program().inst(
        [
            RX(math.pi / 2.0, q[1]),
            H(q[2]),
            CNOT(q[0], q[1]),
            CNOT(q[1], q[2]),
            RZ(2.0, q[2]),
            CNOT(q[1], q[2]),
            CNOT(q[0], q[1]),
            RX(-math.pi / 2.0, q[1]),
            H(q[2]),
        ]
    )
    assert address_qubits(prog) == address_qubits(result_prog) 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:22,代碼來源:test_paulis_with_placeholders.py

示例9: test_exponentiate_3cob

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_exponentiate_3cob():
    # testing circuit for 3-terms with change of basis
    generator = PauliTerm("Z", 0, 1.0) * PauliTerm("Y", 1, 1.0) * PauliTerm("X", 2, 1.0)
    para_prog = exponential_map(generator)
    prog = para_prog(1)
    result_prog = Program().inst(
        [
            RX(math.pi / 2.0, 1),
            H(2),
            CNOT(0, 1),
            CNOT(1, 2),
            RZ(2.0, 2),
            CNOT(1, 2),
            CNOT(0, 1),
            RX(-math.pi / 2.0, 1),
            H(2),
        ]
    )
    assert prog == result_prog 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:21,代碼來源:test_paulis.py

示例10: test_parameterized_single_qubit_state_preparation

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_parameterized_single_qubit_state_preparation():
    p = Program()
    alpha = p.declare("preparation_alpha", "REAL", 2)
    beta = p.declare("preparation_beta", "REAL", 2)
    gamma = p.declare("preparation_gamma", "REAL", 2)
    p += RZ(alpha[0], 0)
    p += RX(np.pi / 2, 0)
    p += RZ(beta[0], 0)
    p += RX(-np.pi / 2, 0)
    p += RZ(gamma[0], 0)
    p += RZ(alpha[1], 1)
    p += RX(np.pi / 2, 1)
    p += RZ(beta[1], 1)
    p += RX(-np.pi / 2, 1)
    p += RZ(gamma[1], 1)
    assert parameterized_single_qubit_state_preparation([0, 1]).out() == p.out() 
開發者ID:rigetti,項目名稱:pyquil,代碼行數:18,代碼來源:test_program.py

示例11: generate_cz_phase_ramsey_experiments

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def generate_cz_phase_ramsey_experiments(cz_qubits: Sequence[int], measure_qubit: int,
                                         angles: Sequence[float]) -> List[ObservablesExperiment]:
    """
    Return ObservablesExperiments containing programs that constitute a CZ phase ramsey experiment.

    :param cz_qubits: the qubits participating in the cz gate
    :param measure_qubit: Which qubit to measure.
    :param angles: A list of angles at which to make a measurement
    :return: ObservablesExperiments which can be run to estimate the effective RZ rotation
        applied to a single qubit during the application of a CZ gate.
    """
    expts = []
    for angle in angles:
        settings = []
        program = Program()
        # apply CZ, possibly inducing an effective RZ on measure qubit by some angle
        program += CZ(*cz_qubits)
        # apply phase to measure_qubit akin to T2 experiment
        program += RZ(angle, measure_qubit)
        settings = [ExperimentSetting(minusY(measure_qubit), PauliTerm('Y', measure_qubit))]

        expts.append(ObservablesExperiment([settings], program))

    return expts 
開發者ID:rigetti,項目名稱:forest-benchmarking,代碼行數:26,代碼來源:qubit_spectroscopy.py

示例12: _one_q_sic_prep

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def _one_q_sic_prep(index, qubit):
    """Prepare the index-th SIC basis state."""
    if index == 0:
        return Program()

    theta = 2 * np.arccos(1 / np.sqrt(3))
    zx_plane_rotation = Program([
        RX(-pi / 2, qubit),
        RZ(theta - pi, qubit),
        RX(-pi / 2, qubit),
    ])

    if index == 1:
        return zx_plane_rotation

    elif index == 2:
        return zx_plane_rotation + RZ(-2 * pi / 3, qubit)

    elif index == 3:
        return zx_plane_rotation + RZ(2 * pi / 3, qubit)

    raise ValueError(f'Bad SIC index: {index}') 
開發者ID:rigetti,項目名稱:forest-benchmarking,代碼行數:24,代碼來源:observable_estimation.py

示例13: test_expectations_at_depth

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_expectations_at_depth(qvm):
    qvm.qam.random_seed = 5
    q = 0
    qubits = (q, )
    expected_outcomes = [1., 0, -1., 0]
    for depth in [0, 1, 2, 3, 4]:
        prep, meas, settings = rpe.all_eigenvector_prep_meas_settings(qubits, I(q))
        depth_many_rot = [RZ(pi/2, q) for _ in range(depth)]
        program = Program(prep) + sum(depth_many_rot, Program()) + Program(meas)
        expt = ObservablesExperiment(list(settings), program)

        results = list(estimate_observables(qvm, expt))

        for res in results:
            meas_dir = res.setting.observable[q]
            idx = ((depth - 1) if meas_dir == 'Y' else depth) % 4
            expected = expected_outcomes[idx]
            exp = res.expectation
            assert np.allclose(expected, exp, atol=.05) 
開發者ID:rigetti,項目名稱:forest-benchmarking,代碼行數:21,代碼來源:test_robust_phase_estimation.py

示例14: decomposed_diffusion_program

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def decomposed_diffusion_program(qubits: List[int]) -> Program:
    """
    Constructs the diffusion operator used in Grover's Algorithm, acted on both sides by an
    a Hadamard gate on each qubit. Note that this means that the matrix representation of this
    operator is diag(1, -1, ..., -1). In particular, this decomposes the diffusion operator, which
    is a :math:`2**{len(qubits)}\times2**{len(qubits)}` sparse matrix, into
     :math:`\mathcal{O}(len(qubits)**2) single and two qubit gates.

    See C. Lavor, L.R.U. Manssur, and R. Portugal (2003) `Grover's Algorithm: Quantum Database
    Search`_ for more information.

    .. _`Grover's Algorithm: Quantum Database Search`: https://arxiv.org/abs/quant-ph/0301079

    :param qubits: A list of ints corresponding to the qubits to operate on.
                   The operator operates on bistrings of the form
                   ``|qubits[0], ..., qubits[-1]>``.
    """
    program = Program()
    if len(qubits) == 1:
        program.inst(Z(qubits[0]))
    else:
        program.inst([X(q) for q in qubits])
        program.inst(H(qubits[-1]))
        program.inst(RZ(-np.pi, qubits[0]))
        program += (ControlledProgramBuilder()
                              .with_controls(qubits[:-1])
                              .with_target(qubits[-1])
                              .with_operation(X_GATE)
                              .with_gate_name(X_GATE_LABEL).build())
        program.inst(RZ(-np.pi, qubits[0]))
        program.inst(H(qubits[-1]))
        program.inst([X(q) for q in qubits])
    return program 
開發者ID:rigetti,項目名稱:grove,代碼行數:35,代碼來源:amplification.py

示例15: test_param_prog_p1_barbell

# 需要導入模塊: from pyquil import gates [as 別名]
# 或者: from pyquil.gates import RZ [as 別名]
def test_param_prog_p1_barbell():
    test_graph = [(0, 1)]
    p = 1
    with patch('pyquil.api.get_qc', spec=qc_mod):
        inst = maxcut_qaoa(test_graph, steps=p)

    param_prog = inst.get_parameterized_program()
    trial_prog = param_prog([1.2, 3.4])
    result_prog = Program().inst([H(0), H(1), CNOT(0, 1), RZ(3.4, 1),
                                  CNOT(0, 1), X(0), PHASE(1.7, 0), X(0),
                                  PHASE(1.7, 0), H(0), RZ(-2.4, 0), H(0), H(1),
                                  RZ(-2.4, 1), H(1)])
    assert trial_prog == result_prog 
開發者ID:rigetti,項目名稱:grove,代碼行數:15,代碼來源:test_maxcut.py


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