概率测量

概率测量是指获得目标量子比特的振幅,目标量子比特可以是一个量子比特也可以是多个量子比特的集合。 在QPanda2中概率测量又称为PMeasure 。 概率测量和 量子测量 是完全不同的过程,Measure是执行了一次测量, 并返回一个确定的0/1结果,并且改变了量子态,

接口介绍

QPanda2提供了三种获得PMeasure结果的方式,其中有 prob_run_listprob_run_tuple_listprob_run_dict

  • prob_run_list : 获得目标量子比特的概率测量结果列表。

  • prob_run_tuple_list: 获得目标量子比特的概率测量结果,为列表类型,其对应的下标为十进制。

  • prob_run_dict : 获得目标量子比特的概率测量结果,为字典类型,其对应的下标为二进制。

这三个函数的使用方式是一样的,下面就以 prob_run_dict 为例介绍,使用方式如下:

prog = QProg()
prog << H(qubits[0])\
     << CNOT(qubits[0], qubits[1])\
     << CNOT(qubits[1], qubits[2])\
     << CNOT(qubits[2], qubits[3])

result = prob_run_dict(prog, qubits, 3)

第一个参数是量子程序, 第二个参数是 QVec 它指定了我们关注的量子比特。 第三个参的值为-1时,获取所有的概率测量结果,大于0时表示获取最大的前几个数。

实例

from pyqpanda import *

if __name__ == "__main__":
    qvm = CPUQVM()
    qvm.init_qvm()
    qubits = qvm.qAlloc_many(2)
    cbits = qvm.cAlloc_many(2)

    prog = QProg()
    prog << H(qubits[0])\
        << CNOT(qubits[0], qubits[1])

    print("prob_run_dict: ")
    result1 = qvm.prob_run_dict(prog, qubits, -1)
    print(result1)

    print("prob_run_tuple_list: ")
    result2 = qvm.prob_run_tuple_list(prog, qubits, -1)
    print(result2)

    print("prob_run_list: ")
    result3 = qvm.prob_run_list(prog, qubits, -1)
    print(result3)

运行结果:

prob_run_dict:
{'00': 0.4999999999999999, '01': 0.0, '10': 0.0, '11': 0.4999999999999999}
prob_run_tuple_list:
[(0, 0.4999999999999999), (3, 0.4999999999999999), (1, 0.0), (2, 0.0)]
prob_run_list:
[0.4999999999999999, 0.0, 0.0, 0.4999999999999999]

备注

概率测量 不支持噪声虚拟机