QASM转化为量子程序


通过该功能模块,你可以解析QASM文本文件,将其中的量子逻辑门操作信息提取出来,得到QPanda 2内部可操作的量子程序。

QASM介绍


QASM的书写格式规范与例程可以参考量子程序转化QASM模块中的 QASM介绍 部分。

QPanda 2提供了QASM文件转换工具接口 convert_qasm_to_qprog() 该接口使用非常简单,具体可参考下方示例程序。

实例


接下来通过简单的接口调用演示了QASM转化量子程序的过程

#include "QPanda.h"
USING_QPANDA

int main()
{
        // 编写QASM文件
        std::string filename = "testfile.txt";
        std::ofstream os(filename);
        os << R"(// test QASM file
                OPENQASM 2.0;
                include "qelib1.inc";
                qreg q[3];
                creg c[3];
                x q[0];
                x q[1];
                z q[2];
                h q[0];
                tdg q[1];
                measure q[0] -> c[0];
                measure q[1] -> c[1];
                measure q[2] -> c[2];
        )";

        os.close();

        auto machine = initQuantumMachine(QMachineType::CPU);
        QVec out_qv;
        std::vector<ClassicalCondition> out_cv;

        // QASM转换量子程序
        QProg out_prog = convert_qasm_to_qprog(filename, machine, out_qv, out_cv);

        // 量子程序转换QASM,打印并对比转换结果
        std::cout << convert_qprog_to_qasm(out_prog, machine) << std::endl;
        destroyQuantumMachine(machine);
        return 0;
}

具体步骤如下:

  • 首先编写QASM,并将其保存到指定文件中
  • 接着在主程序中用 initQuantumMachine() 初始化一个量子虚拟机对象,用于管理后续一系列行为
  • 然后调用 convert_qasm_to_qprog() 转化
  • 最后调用 convert_qprog_to_qasm() 接口,把量子程序转为QASM,通过比较输入和生成的QASM是否相同,判断QASM是否正确转换成量子程序,并且用 destroyQuantumMachine() 释放系统资源

运行结果如下:

        OPENQASM 2.0;
include "qelib1.inc";
qreg q[3];
creg c[3];
u3(1.5707963267948968,3.1415926535897931,3.1415926535897931) q[0];
u3(3.1415926535897931,0,-2.3561944901923448) q[1];
u3(0,3.1415926535897931,0) q[2];
measure q[0] -> c[0];
measure q[1] -> c[1];
measure q[2] -> c[2];

注解

对于暂不支持的操作类型,可能会在QASM转化成量子程序的过程中发生错误。