CN116151384B - 量子电路处理方法、装置及电子设备 - Google Patents
量子电路处理方法、装置及电子设备 Download PDFInfo
- Publication number
- CN116151384B CN116151384B CN202310158747.9A CN202310158747A CN116151384B CN 116151384 B CN116151384 B CN 116151384B CN 202310158747 A CN202310158747 A CN 202310158747A CN 116151384 B CN116151384 B CN 116151384B
- Authority
- CN
- China
- Prior art keywords
- list
- directed
- target
- instruction
- acyclic graph
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000003672 processing method Methods 0.000 title claims abstract description 17
- 238000012545 processing Methods 0.000 claims abstract description 20
- 239000002096 quantum dot Substances 0.000 claims description 88
- 238000005259 measurement Methods 0.000 claims description 34
- 238000000034 method Methods 0.000 claims description 31
- 238000010276 construction Methods 0.000 claims description 5
- 238000004422 calculation algorithm Methods 0.000 description 16
- 238000010586 diagram Methods 0.000 description 16
- 230000008569 process Effects 0.000 description 13
- 238000004088 simulation Methods 0.000 description 11
- 238000004590 computer program Methods 0.000 description 10
- 238000004891 communication Methods 0.000 description 8
- 238000005457 optimization Methods 0.000 description 7
- 238000004364 calculation method Methods 0.000 description 3
- 230000006870 function Effects 0.000 description 3
- 239000011159 matrix material Substances 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000003287 optical effect Effects 0.000 description 3
- 230000003252 repetitive effect Effects 0.000 description 3
- 230000009471 action Effects 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 2
- 230000001351 cycling effect Effects 0.000 description 2
- 238000005516 engineering process Methods 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 230000009191 jumping Effects 0.000 description 2
- 238000003491 array Methods 0.000 description 1
- 238000013473 artificial intelligence Methods 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 230000007547 defect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000010365 information processing Effects 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000010801 machine learning Methods 0.000 description 1
- 238000012821 model calculation Methods 0.000 description 1
- 239000013307 optical fiber Substances 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 238000012163 sequencing technique Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06N—COMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
- G06N10/00—Quantum computing, i.e. information processing based on quantum-mechanical phenomena
- G06N10/20—Models of quantum computing, e.g. quantum circuits or universal quantum computers
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- Mathematical Analysis (AREA)
- Data Mining & Analysis (AREA)
- Evolutionary Computation (AREA)
- Condensed Matter Physics & Semiconductors (AREA)
- Computational Mathematics (AREA)
- Mathematical Optimization (AREA)
- Pure & Applied Mathematics (AREA)
- Computing Systems (AREA)
- General Engineering & Computer Science (AREA)
- Mathematical Physics (AREA)
- Software Systems (AREA)
- Artificial Intelligence (AREA)
- Optical Modulation, Optical Deflection, Nonlinear Optics, Optical Demodulation, Optical Logic Elements (AREA)
Abstract
本公开提供了一种量子电路处理方法、装置及电子设备,涉及量子计算技术领域,具体涉及量子电路技术领域。具体实现方案为:获取第一量子电路的第一指令列表;基于所述第一指令列表,确定第一有向无环图;基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图;基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
Description
技术领域
本公开涉及量子计算技术领域,尤其涉及量子电路技术领域,具体涉及一种量子电路处理方法、装置及电子设备。
背景技术
量子计算利用量子世界中特有的运行规律,提供了一条全新的并且非常有前景的信息处理方式。在诸多特定问题上,量子算法可以带来超越经典算法的优势。例如,利用秀尔(Shor)算法,可以对大整数进行高效的分解,利用格罗弗(Grover)算法,可以更快的进行数据搜索。随着量子理论的发展,不断有新的量子算法被提出,如何高效的对这些算法进行模拟或者在真正的量子硬件上运行始终是一个重要的问题。
目前,量子算法的经典模拟或者真机运行主要受限于量子比特的数量。在经典模拟上,由于描述量子态的列向量的长度随对应比特数呈指数增长(例如一个n比特的量子态的列向量长度为2n),经典计算机很难模拟大规模的量子算法。受计算机内存和处理器能力的限制,现有的量子电路模拟方式最多能支持模拟几十个量子比特的算法。
发明内容
本公开提供了一种量子电路处理方法、装置及电子设备。
根据本公开的第一方面,提供了一种量子电路处理方法,包括:
获取第一量子电路的第一指令列表;
基于所述第一指令列表,确定第一有向无环图,所述第一有向无环图包括所述第一指令列表中指令对应的节点和至少两个第一有向边,所述第一有向边用于表征所述第一指令列表中不同指令间的时序关系,所述至少两个第一有向边构成的路径不包括有向环路;
基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,所述第二有向无环图包括第二有向边和所述至少两个第一有向边,所述第二有向边和所述至少两个第一有向边构成的路径不包括有向环路,所述输入节点列表包括所述第一指令列表中类型为重置操作指令对应的节点,所述输出节点列表包括所述第一指令列表中类型为量子测量操作指令对应的节点,所述第二有向边为所述输出节点列表中输出节点与所述输入节点列表中输入节点的有向边,所述第二有向无环图中,每个输出节点至多与一个输入节点相连,不同输出节点不能与同一个输入节点相连;
基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
根据本公开的第二方面,提供了一种量子电路处理装置,包括:
获取模块,用于获取第一量子电路的第一指令列表;
第一确定模块,用于基于所述第一指令列表,确定第一有向无环图,所述第一有向无环图包括所述第一指令列表中指令对应的节点和至少两个第一有向边,所述第一有向边用于表征所述第一指令列表中不同指令间的时序关系,所述至少两个第一有向边构成的路径不包括有向环路;
第二确定模块,用于基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,所述第二有向无环图包括第二有向边和所述至少两个第一有向边,所述第二有向边和所述至少两个第一有向边构成的路径不包括有向环路,所述输入节点列表包括所述第一指令列表中类型为重置操作指令对应的节点,所述输出节点列表包括所述第一指令列表中类型为量子测量操作指令对应的节点,所述第二有向边为所述输出节点列表中输出节点与所述输入节点列表中输入节点的有向边,所述第二有向无环图中,每个输出节点至多与一个输入节点相连,不同输出节点不能与同一个输入节点相连;
等效编译模块,用于基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
根据本公开的第三方面,提供了一种电子设备,包括:
至少一个处理器;以及
与至少一个处理器通信连接的存储器;其中,
存储器存储有可被至少一个处理器执行的指令,该指令被至少一个处理器执行,以使至少一个处理器能够执行第一方面中的任一项方法。
根据本公开的第四方面,提供了一种存储有计算机指令的非瞬时计算机可读存储介质,该计算机指令用于使计算机执行第一方面中的任一项方法。
根据本公开的第五方面,提供了一种计算机程序产品,包括计算机程序,该计算机程序在被处理器执行时实现第一方面中的任一项方法。
根据本公开的技术解决了相关技术中量子电路的经典模拟和真机运行比较难的问题,使得能够实现对大规模量子比特的量子电路进行经典模拟和真机运行。
应当理解,本部分所描述的内容并非旨在标识本公开的实施例的关键或重要特征,也不用于限制本公开的范围。本公开的其它特征将通过以下的说明书而变得容易理解。
附图说明
附图用于更好地理解本方案,不构成对本公开的限定。其中:
图1是根据本公开第一实施例的量子电路处理方法的流程示意图;
图2是一示例的量子电路图的结构示意图;
图3是第一量子电路的结构示意图;
图4是第一有向无环图的结构示意图;
图5是第二有向无环图的结构示意图;
图6是第二量子电路的结构示意图;
图7是根据本公开第二实施例的量子电路处理装置的结构示意图;
图8是用来实施本公开的实施例的示例电子设备的示意性框图。
具体实施方式
以下结合附图对本公开的示范性实施例做出说明,其中包括本公开实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本公开的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
第一实施例
如图1所示,本公开提供一种量子电路处理方法,包括如下步骤:
步骤S101:获取第一量子电路的第一指令列表。
本实施例中,量子电路处理方法涉及量子计算技术领域,尤其涉及量子电路技术领域,其可以广泛应用于量子电路的经典模拟和真机运行场景下。本公开实施例的量子电路处理方法,可以由本公开实施例的量子电路处理装置执行。本公开实施例的量子电路处理装置可以配置在任意电子设备中,以执行本公开实施例的量子电路处理方法。
受计算机内存和处理器能力的限制,现有的量子电路模拟方式最多能支持模拟几十个量子比特的算法。比如,笔记本能模拟20-30个左右的量子比特,大型超级计算机和集群可以最多模拟30-40个左右的量子比特。在真机运行上,由于当前量子芯片的可扩展性问题尚未解决,导致量子计算机能提供的量子比特数非常有限。因此,量子电路优化是量子计算领域中的一个基本问题。
量子电路优化是通过一定的技术手段,可以将给定的量子电路进行简化,以降低其经典模拟和真机运行的要求,进而加速量子算法的研究和量子计算在实际场景下的落地。
而本实施例的量子电路处理可以为量子电路优化的处理,其目的在于通过对量子电路进行优化编译,可以使得编译得到的量子电路在量子比特数上对原量子电路进行大量简化。一方面,可以进一步提升量子算法经典模拟的规模,加强经典计算机对量子算法的验证能力,另一方面,也可以降低量子算法在真机运行上的比特数要求,弥补当前量子芯片可扩展性问题的不足。
以下详细介绍量子电路模型。
量子电路模型是一种常用的量子计算模型。通过对初始量子态进行量子门操作完成量子态的演化,并通过量子测量提取计算结果。而量子电路图则表示了量子电路模型计算的全部过程。
图2是一示例的量子电路图的结构示意图,如图2所示,可以用一根水平线表示一个量子比特系统,从上至下依次对量子比特位进行标号,其中,量子位的标号往往从零开始。
量子电路图中时间演化的方向从左到右,最左端为初始的量子态,其中,通常每个量子比特初始化为零态,之后对初始态依次作用不同的量子门操作以完成量子态的演化。同时可以对某些量子位进行量子测量,获得测量结果。
在一些应用场景中,量子电路中的操作可能会出现对一部分量子比特进行量子测量,并根据测量结果来调控其余的量子比特的演化,此类操作称为经典控制量子操作,如图2所示的经典控制量子门201。而经过测量后的量子比特则可以被重置,该类操作可以称之为重置操作,如图2所示的重置操作202,以供后续计算继续使用。可以将包含中间测量、经典控制量子操作以及重置操作的量子电路称为动态量子电路,如图2表示的量子电路即为动态量子电路。
量子电路图中除了初始态之外其余部分,通常可以按照量子门的作用顺序用一个有序的指令列表进行表示,列表中的每一个元素代表一个量子门、经典控制量子门、量子测量或重置操作指令。具体地,可以将:
每一个单量子比特门(如H,X,Y,Z,S,T,Rx,Ry,Rz等)表示为一个包含四个元素的指令[name,which_qubit,parameters,condition]。其中,name为量子门的名称,which_qubit为量子门作用的量子位,parameters为量子门的参数(如没有参数则默认为None),condition表示该量子门操作受哪一个量子位的测量结果控制(如果没有参数则默认为None)。
例如,[Rx,2,pi,None]表示对量子位2上的量子比特作用一个Rx旋转门,旋转角度为pi。又例如,图2中经典控制量子门201为经典受控量子X门,可以表示为[X,2,None,‘a’],即作用在量子位2上的泡利Pauli X门,受控条件为测量标识ID为‘a’的测量结果,测量结果为0则不作用量子门,测量结果为1则作用量子门。
每一个双量子比特门(如控制非门CNOT,CZ门)表示为一个包含四个元素的指令[name,which_qubit,parameters,condition]。其中,name为量子门的名称,which_qubit为该双量子比特门作用的量子位构成的列表(特别地,对于受控量子门,为控制位和受控位构成的列表),parameters为量子门的参数(如没有参数则默认为None),condition表示该量子门操作受哪一个量子位的测量结果控制(如果没有参数则默认为None)。
例如,[CNOT,[1,3],None,None]表示对量子位1和量子位3作用控制非门,其中,量子位1为控制位,量子位3为受控位。[CZ,[1,2],None,None]表示在量子位1和量子位2之间作用CZ门。
每一个单比特测量表示为一个包含四个元素的指令[measure,which_qubit,basis,mid]。其中,basis由四个参数决定,其包括测量角度angle,测量平面plane,域集s,域集t,而mid为标识当前测量的标识ID。
例如,[measure,2,[0,‘YZ’,[1],[2]],‘a’]表示对量子位2进行测量,测量角度为0,测量平面为‘YZ’平面,域集s为量子位1,域集t为量子位2,当前测量指令的标识ID为‘a’。
每一个重置操作指令可以表示为一个包含四个元素的指令[reset,which_qubit,matrix,None]。其中,which_qubit为需要重置的量子位,matrix为需要重置比特的量子态矩阵,经过重置操作后的量子比特可供后续计算继续使用。
在步骤S101中,第一量子电路可以为动态量子电路,按照第一量子电路中量子门的作用顺序用一个有序的指令列表表示,该指令列表即为第一指令列表,其内可以包括第一量子电路的操作指令,第一指令列表中的每一个元素代表一个量子门、经典控制量子门、量子测量或重置操作指令。
可以获取预先存储的第一量子电路的第一指令列表,也可以获取用户输入的第一量子电路的第一指令列表,这里不进行具体限定。
步骤S102:基于所述第一指令列表,确定第一有向无环图,所述第一有向无环图包括所述第一指令列表中指令对应的节点和至少两个第一有向边,所述第一有向边用于表征所述第一指令列表中不同指令间的时序关系,所述至少两个第一有向边构成的路径不包括有向环路。
该步骤中,第一有向无环图可以包括节点和由节点构成的第一有向边,每个节点表示第一量子电路中的一个电路指令,其中,节点标识可以为第一指令列表中的指令,也可以为第一指令列表中指令对应的标识,这里不进行具体限定。
第一有向边指的是带有指向(即方向性)的边,表示第一指令列表中不同指令间的时序关系,如节点A指向节点B的边表示节点A对应指令需要在节点B对应指令之前完成执行。
第一有向无环图中,各个第一有向边所构成的任一路径均不是有向环路,有向环路指的是带有方向性的环路,如节点A、节点B和节点C,若节点A指向节点B,节点B指向节点C、节点C再指向节点A,则节点A、节点B和节点C构成了一条有向环路。
由于量子电路中指令的时序关系可以基于量子电路的指令列表中指令的排列顺序体现,因此,可以基于第一量子电路的第一指令列表中指令的排列顺序,构建第一有向无环图。
在一可选实施方式中,可以基于第一指令列表中指令的数量,构建相应数量的节点,并基于第一指令列表中指令的排列顺序,确定各个指令之间的时序关系,基于该时序关系,在所构建的节点之间连接有向边,从而可以得到第一有向无环图。
在另一可选实施方式中,可以进行第一指令列表中指令的循环遍历,针对当前遍历的指令,在该当前遍历的指令之前查找与之存在时序关系的其他指令,相应构建存在时序关系的节点,并构建一条有向边,将其添加至图中,在循环遍历完成的情况下,即可以得到第一有向无环图。
步骤S103:基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,所述第二有向无环图包括第二有向边和所述至少两个第一有向边,所述第二有向边和所述至少两个第一有向边构成的路径不包括有向环路,所述输入节点列表包括所述第一指令列表中类型为重置操作指令对应的节点,所述输出节点列表包括所述第一指令列表中类型为量子测量操作指令对应的节点,所述第二有向边为所述输出节点列表中输出节点与所述输入节点列表中输入节点的有向边,所述第二有向无环图中,每个输出节点至多与一个输入节点相连,不同输出节点不能与同一个输入节点相连。
该步骤中,由于将一个量子电路编译成另一个量子电路,本质上是通过对已经测量的量子比特进行重置回收,以供后续指令所使用。对应第一有向无环图,相当于需要尽可能向图中添加从输出节点指向输入节点的有向边,以表示测量比特重置被重新利用,相应的,可以减少量子电路中所需要的量子比特数。
其中,输出节点为第一指令列表中类型为量子测量操作指令对应的节点,输入节点为第一指令列表中类型为重置操作指令对应的节点。
为了保证所编译得到的量子电路与原量子电路的等效性,以及保证量子电路中指令之间的时序关系,在添加有向边时需要保证如下约束条件:
1)为了使得整个图依然符合电路指令的时序关系,需要保证在加入更多有向边之后,整个图依然是无环的,需要注意的是,图中有向边的指向表示指令的时序关系,环状结构将会破坏这种关系,也即添加有向边之后,图中依然不能存在环状结构的路径(称之为有向环路);
2)每个输出节点最多只能和一个输入节点相连,以表示输出节点测量后,由所指向的输入节点继续在该量子比特上执行操作;
3)不同输出节点不能和同一个输入节点相连。
相应的,在第一有向无环图中添加符合上述约束条件的第二有向边之后,可以得到第二有向无环图。
步骤S104:基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
该步骤中,添加输出节点至输入节点的有向边之后,可以基于第二有向无环图,确定各个节点之间的时序关系,并基于该时序关系,对第一指令列表进行重排序,之后,可以利用第一目标列表中输入节点与输出节点之间的关系,将测量指令之后作用在其他量子比特(即与输出节点有向连接的输入节点对应指令所作用的量子比特)的指令,等效编译成作用到该测量指令所作用的量子比特上,如此,可以实现对第一量子电路的等效编译,得到与第一量子电路等效的第二量子电路的第二指令列表,第二量子电路中所需要的量子比特比第一量子电路中所需要的量子比特少。
本实施例中,通过将量子电路编译转化为有向无环图,并通过在有向无环图中添加输出节点至输入节点的有向边,以表示测量比特重置被重新利用。之后可以基于添加了输出节点至输入节点的有向边的有向无环图,对第一量子电路进行等效编译,得到第二量子电路,如此可以有效减少等效编译得到的量子电路中所需要的量子比特数,实现量子电路的优化,使得能够实现对大规模量子比特的量子电路进行经典模拟和真机运行。
可选的,所述步骤S102具体包括:
对所述第一指令列表按照从左至右的指令排列顺序进行遍历,并获取第二目标列表和当前遍历的指令所作用的第一量子位,所述第二目标列表包括所述第一指令列表中排序在所述当前遍历的指令之前的指令;
对所述第二目标列表按照从右至左的指令排列顺序进行遍历,并获取第一目标指令,所述第一目标指令所作用的量子位与所述第一量子位存在交集;
将所述第一目标指令的标识作为源节点,所述当前遍历的指令的标识作为目标节点,构建所述第一有向边;
在所述第一指令列表遍历完成的情况下,基于所构建的第一有向边,获取所述第一有向无环图。
本实施方式中,量子电路至第一有向无环图的转化过程如下:
输入:量子电路指令列表circuit_list;
输出:有向无环图(为第一有向无环图),输入节点列表,输出节点列表。
步骤1:根据量子电路指令列表circuit_list所表示的电路宽度,记录为n;循环遍历列表[0,1,…,n-1],记当前被循环的元素为idx,生成电路指令gate=[reset,idx,[[1],[0]],None],并添加至circuit_list列表最前面,获得更新后的列表circuit_list,即得到第一指令列表;
步骤2:循环遍历列表circuit_list,记当前被循环的元素为gate,且gate处于circuit_list的第i位,为gate添加一个ID属性,ID的值为i;
步骤3:初始化一个有向图graph,初始化两个空列表input_ids和output_ids;
步骤4:循环遍历列表circuit_list(即按照从左至右的指令排列顺序遍历),记当前被循环的元素为gate,且gate处于circuit_list的第i位,执行如下操作a)、b):
操作a)记录circuit_list中的前i个元素构成的列表为pre_gates(即第二目标列表);
操作b)获取gate指令所作用的量子位(即第一量子位),记当前被循环的量子位为idx;
操作c)反向循环遍历pre_gates(即按照从右至左的指令排列顺序遍历),并记当前被循环的元素为pre_gate;如果pre_gate所作用的量子位与idx有交集,则pre_gate为第一目标指令;记node1为pre_gate指令的标识ID,node2为gate指令的标识ID,向有向图graph中构建并添加节点node1和node2,添加一条从node1(源节点)指向node2(目标节点)的有向边;之后跳出本层循环;
步骤5:如果gate为重置指令,则将其对应ID加入到input_ids列表最末尾;如果gate为测量指令,则将其对应ID加入到output_ids列表最末尾;
步骤6:返回有向图graph(第一有向无环图),输入节点列表input_ids和输出节点列表output_ids。
本实施方式中,通过进行第一指令列表中指令的循环遍历,针对当前遍历的指令,在该当前遍历的指令之前查找与之存在时序关系(即两个指令作用有相同量子位)的其他指令,相应构建存在时序关系的节点,并构建一条有向边,将其添加至图中,在循环遍历完成的情况下,即可以得到第一有向无环图。如此,可以简单地实现第一有向无环图的构建。
另外,在构建第一有向无环图时,仅使用对应指令的ID即可,无需用电路指令本身作为图的节点,以尽可能减少相应运算。
在一示例中,量子电路的结构示意图如图3所示,其中,H表示H门,M表示测量measure,*-X表示CNOT门。
添加重置操作指令之后,第一量子电路的第一指令列表如下为[[reset,0,[[1],[0]],None];[reset,1,[[1],[0]],None];[reset,2,[[1],[0]],None];[h,0,None,None];[h,1,None,None];[h,2,None,None];[cnot,[0,1],None,None];[cnot,[1,2],None,None];[measure,0,[0,‘YZ’,[],[]],(0,1)];[measure,1,[0,‘YZ’,[],[]],(1,1)];[measure,2,[0,‘YZ’,[],[]],(2,1)]]。
按照量子电路至第一有向无环图的转化过程,为每个指令分配的ID依次为0,1,…,10,得到的第一有向无环图如图4所示。其中,每个节点上的数字为对应指令的ID,节点401为输入节点,节点402为输出节点。
可选的,所述步骤S103具体包括:
针对所述输出节点列表中每个输出节点,获取所述输出节点对应的第一集合,在基于所述第一有向无环图确定所述输入节点列表中存在无法到达所述输出节点的目标输入节点的情况下,所述第一集合包括所述目标输入节点;
将各输出节点对应的所述第一集合进行笛卡尔积,得到包括目标可行解的第二集合,所述目标可行解指示各输出节点可进行连接的输入节点,所述目标可行解中用于指示输入节点的标识不可重复;
基于所述第二集合,在所述第一有向无环图中构建所述第二有向边,得到所述第二有向无环图。
本实施方式中,针对输出节点列表中每个输出节点,可以获取输出节点的不可达节点列表(即第一集合),不可达节点列表包括目标输入节点,该目标输入节点在第一有向无环图中是没有路径到达输出节点的,也即该目标输入节点与该输出节点是可连接的,满足约束条件,在两者连接的情况下,不会带入环状结构的路径。
如图4所示,针对输出节点m8,输入节点r0和r1均可以到达该输出节点,因此,输出节点m8的不可达节点列表为[r2],针对输出节点m9和m10,输入节点r0、r1和r2均可以到达该输出节点,输出节点m9和输出节点m10的不可达节点列表均为[None]。
之后,将各输出节点对应的第一集合进行笛卡尔积,以得到指示各个输出节点可连接的输入节点的目标可行解,目标可行解实质上指示各个输出节点与输入节点连接的一种方式。
比如,输出节点m8的不可达节点列表为[r2],输出节点m9和输出节点m10的不可达节点列表均为[None],进行笛卡尔积之后,可以得到包括目标可行解的第二集合,其中,目标可行解可以为[r2,None,None],指示输出节点m8可与输入节点r2连接,输出节点m9和输出节点m10均不与任何输入节点连接。
实现过程中,可以向不可达节点列表中最末尾添加元素None,以表示该输出节点不与任何输入节点进行连接,如输出节点m8的不可达节点列表可以为[r2,None]。在进行笛卡尔积之后,可以得到所有可行解构成的空间。可以循环可行解的空间,在判断可行解中除None元素以外,还存在其他的重复性元素,则将该可行解删除。相应的,第二集合仅包括目标可行解,该目标可行解中用于指示输入节点的标识(即除None元素以外的元素)不可重复,这样可以满足约束条件,即不同输出节点不能和同一输入节点相连。
在一可选实施方式中,可以从第二集合中任意选择一个目标可行解,基于该目标可行解,在第一有向无环图中构建所述第二有向边,在构建过程中,可以判定所构建有向边之后的图中是否存在环状结构的路径,若不存在,则将所构建的图确定为第二有向无环图。若存在,则可以重新选择一个目标可行解,重复上述过程,直至所构建有向边之后的图中不存在环状结构的路径,得到第二有向无环图。
在另一可选实施方式中,可以对第二集合中的目标可行解按照非None元素的个数进行排序,其中,目标可行解中非None元素的个数可以指示输出节点与输入节点所连接边的数量。并按照排列顺序进行目标可行解的选择,以基于所选择的目标可行解构建第二有向无环图。
本实施方式中,针对所述输出节点列表中每个输出节点,获取所述输出节点对应的第一集合,在基于所述第一有向无环图确定所述输入节点列表中存在无法到达所述输出节点的目标输入节点的情况下,所述第一集合包括所述目标输入节点;将各输出节点对应的所述第一集合进行笛卡尔积,得到包括目标可行解的第二集合,所述目标可行解指示各输出节点可进行连接的输入节点,所述目标可行解中用于指示输入节点的标识不可重复;基于所述第二集合,在所述第一有向无环图中构建所述第二有向边,得到所述第二有向无环图。如此,可以将量子电路编译转化为有向无环图的处理,使得在满足约束条件的情况下,实现在第一有向无环图中添加输出节点至输入节点的第二有向边,以在等效编译的同时减少量子电路中所需要的量子比特,实现量子电路的优化。
可选的,所述基于所述第二集合,在所述第一有向无环图中构建第二有向边,得到所述第二有向无环图,包括:
基于所述目标可行解中用于指示输入节点的标识的数量,对所述第二集合中的目标可行解进行排序,得到第三目标列表,所述第三目标列表中,第一目标可行解排序在第二目标可行解之前,所述第一目标可行解中用于指示输入节点的标识的数量大于所述第二目标可行解中用于指示输入节点的标识的数量;
对所述第三目标列表按照从左至右的排列顺序进行遍历,基于当前遍历的目标可行解,在所述第一有向无环图中构建有向边,得到目标有向图;
在确定所述目标有向图中有向边所构成的路径不包括有向环路的情况下,将在所述第一有向无环图构建的有向边确定为所述第二有向边,并将所述目标有向图确定为所述第二有向无环图。
本实施方式中,可以对第二集合中的目标可行解按照非None元素的个数进行排序,非None元素指示的是输入节点的标识,基于目标可行解中用于指示输入节点的标识的数量对第二集合中的目标可行解进行排序,其目的是将引入有向边多的目标可行解排在前面,尽可能多地向图中添加从输出节点指向输入节点的有向边,这样将输出节点和输入节点连接的越多,所编译出来的量子电路所需要的量子比特数则会越少,从而可以保证编译出来的量子电路在量子比特数上的最优性。
之后,可以对第三目标列表按照从左至右的排列顺序进行遍历,这样非None元素的个数越多的目标可行解,其遍历到的时机越早,从而保证所选择的目标可行解的最优性。
基于当前遍历的目标可行解,在第一有向无环图中构建该目标可行解指示的有向边,得到目标有向图,如目标可行解为[r2,None,None],则指示在输出节点m8与输入节点r2之间构建有向边。
判定所得到的目标有向图中是否存在环状结构的路径即有向环路,若是,则继续进行第三目标列表的遍历,选择下一个目标可行解,执行构建有向边和有向环路的判定,直至找到符合条件(即所构建的目标有向图中不包括有向环路)的目标可行解。若否,则将目标可行解确定为有效解,并将基于该目标可行解所构建的目标有向图确定为第二有向无环图。
如此,通过将量子电路编译转化为有向无环图的处理,并通过有序搜索目标可行解的方式,搜索保证编译出来的量子电路在量子比特数上的最优性的有效解,从而可以将给定的量子电路编译成与其等价的动态量子电路,并且使得编译后的动态量子电路所需的比特数达到最小,以使得能够实现对大规模量子比特的量子电路进行经典模拟和真机运行。
有序搜索目标可行解的过程如下:
输入:有向无环图graph(即第一有向无环图),输入节点列表inputs,输出节点列表outputs;
输出:更新后的有向无环图(即第二有向无环图),新加入的有向边列表(即第一目标列表)。
步骤1:对输出节点列表中的每个元素,找到相应可连接的输入节点,具体地,循环遍历输出节点列表outputs,记当前被遍历的元素为output,判断输入节点inputs中哪些元素在图graph中不存在到达节点output的通路,记这些输入节点构成的列表为output节点的不可达节点列表,并向该列表中最末尾添加元素None,以表示该输出节点不与任何输入节点进行连接;
步骤2:将所有输出节点对应的不可达节点列表进行笛卡尔积,以构成所有可行解构成的空间,记笛卡尔积的结果为solutions;
步骤3:循环遍历solutions列表,记录当前被循环元素为solution,判断solution中是否有除None元素以外其他的重复性元素,如果有,则将solution从solutions列表中删除;
步骤4:根据solutions列表中每个元素solution中非None元素的个数进行排序,使得非None元素个数多的solution排在solutions列表前面;
步骤5:循环遍历更新后的solutions列表,记当前被循环的元素为solution;生成一个有向无环图graph的拷贝,记录为new_graph;对于outputs中每个输出节点output,找到solution中对应位置元素的值node,如果node不是None,则生成一条从output指向node的有向边,记该规则生成的所有有向边列表为new_edges,并将这些有向边添加至new_graph(即目标有向图)中;
步骤6:判断上述步骤中新加入的有向边在new_graph中是否产生环,如果产生环,则表明solution不是一个有效解,跳出并继续本轮循环;如果不产生环,则当前solution是一个有效解,返回new_graph和new_edges作为输出。
该过程中,找到所有可行解solution后需要根据其中的非None的元素对其进行排序。这样可以把引入边多的解排在前面,将输出节点和输入节点连接的越多,编译出来的电路所需要的比特数则会越少。这样排序后再依次判断当前解是否会引入环状结构,如果引入环状结构,则继续搜索下一个解,如果不引入环状结构,则是一个有效解,可以直接返回基于该有效解所构建的有向边和有向无环图。由于可行解已经经过排序,所以找到的有效解即为最优解。
如图4所示,基于该图通过上述过程可以找到一个有效解,即添加一条从m8指向r2的一条有向边,更新后的有向无环图如图5所示。
可选的,所述步骤S104具体包括:
基于所述第二有向无环图,对所述第一指令列表中的指令进行重排序,得到第三指令列表;
基于所述第一目标列表,对所述第三指令列表中的指令进行等效编译,得到所述第二指令列表。
本实施方式中,可以基于第二有向无环图,对第一量子电路的第一指令列表中指令进行重排序,得到第三指令列表。其中,第三指令列表中指令的排列顺序与第二有向无环图中节点的拓扑结构匹配。
第三指令列表中指令的排列顺序与第二有向无环图中节点的拓扑结构匹配,指的是若第二有向无环图中有一条节点A指向节点B的有向边,则第三指令列表中节点A对应指令排序在节点B对应指令之前。
在一可选实施方式中,可以通过指令之间的交换方式来基于第二有向无环图,对第一指令列表中的指令进行重排序,如进行图遍历,根据遍历到的节点和有向边,交换第一指令列表中相关的两个指令,使之与图的拓扑结构匹配。
在另一可选实施方式中,可以获取第二有向无环图对应的拓扑排序列表;基于该拓扑排序列表,对第一指令列表中的指令进行重排序。
之后,可以基于第一目标列表,对第三指令列表中的指令进行等效编译,得到第二指令列表。其中,等效编译的目的是将输入节点对应指令所作用的量子比特重新作用到输出节点测量后被重新利用的量子比特上,这样可以减少所编译得到的量子电路的量子比特数,如此实现量子电路的优化。
可选的,所述基于所述第二有向无环图,对所述第一指令列表中的指令进行重排序,得到第三指令列表,包括:
获取所述第二有向无环图对应的拓扑排序列表,所述拓扑排序列表中,针对所述第二有向无环图中的每个有向边,所述有向边的源节点排序在所述有向边的目标节点之前;
基于所述拓扑排序列表,对所述第一指令列表中的指令进行重排序,得到所述第三指令列表。
本实施方式中,拓扑排序列表指的是表征第二有向无环图拓扑结构的列表,比如,图中有一条节点A指向节点B的有向边,则在拓扑排序列表中节点A将会排在节点B的前面。可以通过遍历第二有向无环图的方式获取该拓扑排序列表。
之后,可以基于该拓扑排序列表,对第一指令列表中的指令进行重排序,比如,可以初始化一个空的指令列表,遍历该拓扑排序列表,按照该拓扑排序列表的排列顺序,将第一指令列表中该拓扑排序列表中节点对应指令排列到该指令列表,得到第三指令列表。
如此,可以实现对第一指令列表的重排序。
可选的,所述基于所述第一目标列表,对所述第三指令列表中的指令进行等效编译,得到所述第二指令列表,包括:
针对所述第一目标列表中每个所述第二有向边,对所述第三指令列表中各第二目标指令所作用的第二量子位更新为第三量子位,所述第二量子位为所述第二有向边中目标节点对应指令所作用的量子位,所述第三量子位为所述第二有向边中源节点对应指令所作用的量子位。
本实施方式中,第二有向边中,源节点指的是输出节点,目标节点指的是输入节点。可以将输入节点对应指令所作用的量子比特(即第二量子位对应量子比特)重新作用到输出节点测量后被重新利用的量子比特(即第三量子位对应量子比特)上,这样可以减少所编译得到的量子电路的量子比特数,如此实现量子电路的优化。
第二有向无环图至量子电路的等效编译过程如下:
输入:量子电路指令列表circuit_list(即第一指令列表),有向无环图graph(即第二有向无环图),有向边列表edges(即第一目标列表);
输出:编译后的量子电路指令列表(即第二指令列表)。
步骤1:根据有向无环图graph,获得其对应的拓扑排序列表,并记为sorted_gate_ids;
步骤2:根据sorted_gate_ids的顺序,对量子电路指令列表circuit_list进行排序;
步骤3:循环遍历有向边列表edges,记当前被循环的元素为edge,记edge的源节点对应电路指令所作用的量子位为new_idx,记edge的目标节点对应电路指令所作用的量子位为old_idx;循环遍历circuit_list,对所有作用在量子位old_idx上的指令,改写为作用在new_idx上;
步骤4:返回更新后的量子电路指令列表circuit_list作为输出。
如图5所示,基于该图进行量子电路的等效编译,可以得到编译后的量子电路如图6所示,对应的电路指令列表为[[reset,0,[[1],[0]],None];[reset,1,[[1],[0]],None];[h,0,None,None];[h,1,None,None];[cnot,[0,1],None,None];[measure,0,[0,‘YZ’,[],[]],(0,1)];[reset,0,[[1],[0]],None];[h,0,None,None];[cnot,[1,0],None,None];[measure,1,[0,‘YZ’,[],[]],(1,1)];[measure,0,[0,‘YZ’,[],[]],(2,1)]]。可知,图6相对于图3,量子电路优化后,其所需要的量子比特的数量减少了。
第二实施例
如图7所示,本公开提供一种量子电路处理装置700,包括:
获取模块701,用于获取第一量子电路的第一指令列表;
第一确定模块702,用于基于所述第一指令列表,确定第一有向无环图,所述第一有向无环图包括所述第一指令列表中指令对应的节点和至少两个第一有向边,所述第一有向边用于表征所述第一指令列表中不同指令间的时序关系,所述至少两个第一有向边构成的路径不包括有向环路;
第二确定模块703,用于基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,所述第二有向无环图包括第二有向边和所述至少两个第一有向边,所述第二有向边和所述至少两个第一有向边构成的路径不包括有向环路,所述输入节点列表包括所述第一指令列表中类型为重置操作指令对应的节点,所述输出节点列表包括所述第一指令列表中类型为量子测量操作指令对应的节点,所述第二有向边为所述输出节点列表中输出节点与所述输入节点列表中输入节点的有向边,所述第二有向无环图中,每个输出节点至多与一个输入节点相连,不同输出节点不能与同一个输入节点相连;
等效编译模块704,用于基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
可选的,所述第一确定模块702,具体用于:
对所述第一指令列表按照从左至右的指令排列顺序进行遍历,并获取第二目标列表和当前遍历的指令所作用的第一量子位,所述第二目标列表包括所述第一指令列表中排序在所述当前遍历的指令之前的指令;
对所述第二目标列表按照从右至左的指令排列顺序进行遍历,并获取第一目标指令,所述第一目标指令所作用的量子位与所述第一量子位存在交集;
将所述第一目标指令的标识作为源节点,所述当前遍历的指令的标识作为目标节点,构建所述第一有向边;
在所述第一指令列表遍历完成的情况下,基于所构建的第一有向边,获取所述第一有向无环图。
可选的,所述第二确定模块703包括:
获取单元,用于针对所述输出节点列表中每个输出节点,获取所述输出节点对应的第一集合,在基于所述第一有向无环图确定所述输入节点列表中存在无法到达所述输出节点的目标输入节点的情况下,所述第一集合包括所述目标输入节点;
笛卡尔积单元,用于将各输出节点对应的所述第一集合进行笛卡尔积,得到包括目标可行解的第二集合,所述目标可行解指示各输出节点可进行连接的输入节点,所述目标可行解中用于指示输入节点的标识不可重复;
构建单元,用于基于所述第二集合,在所述第一有向无环图中构建所述第二有向边,得到所述第二有向无环图。
可选的,所述构建单元,具体用于:
基于所述目标可行解中用于指示输入节点的标识的数量,对所述第二集合中的目标可行解进行排序,得到第三目标列表,所述第三目标列表中,第一目标可行解排序在第二目标可行解之前,所述第一目标可行解中用于指示输入节点的标识的数量大于所述第二目标可行解中用于指示输入节点的标识的数量;
对所述第三目标列表按照从左至右的排列顺序进行遍历,基于当前遍历的目标可行解,在所述第一有向无环图中构建有向边,得到目标有向图;
在确定所述目标有向图中有向边所构成的路径不包括有向环路的情况下,将在所述第一有向无环图构建的有向边确定为所述第二有向边,并将所述目标有向图确定为所述第二有向无环图。
可选的,所述等效编译模块704包括:
重排序单元,用于基于所述第二有向无环图,对所述第一指令列表中的指令进行重排序,得到第三指令列表;
等效编译单元,用于基于所述第一目标列表,对所述第三指令列表中的指令进行等效编译,得到所述第二指令列表。
可选的,所述重排序单元,具体用于:
获取所述第二有向无环图对应的拓扑排序列表,所述拓扑排序列表中,针对所述第二有向无环图中的每个有向边,所述有向边的源节点排序在所述有向边的目标节点之前;
基于所述拓扑排序列表,对所述第一指令列表中的指令进行重排序,得到所述第三指令列表。
可选的,所述等效编译单元,具体用于:
针对所述第一目标列表中每个所述第二有向边,对所述第三指令列表中各第二目标指令所作用的第二量子位更新为第三量子位,所述第二量子位为所述第二有向边中目标节点对应指令所作用的量子位,所述第三量子位为所述第二有向边中源节点对应指令所作用的量子位。
本公开提供的量子电路处理装置700能够实现量子电路处理方法实施例实现的各个过程,且能够达到相同的有益效果,为避免重复,这里不再赘述。
本公开的技术方案中,所涉及的用户个人信息的收集、存储、使用、加工、传输、提供和公开等处理,均符合相关法律法规的规定,且不违背公序良俗。
根据本公开的实施例,本公开还提供了一种电子设备、一种可读存储介质和一种计算机程序产品。
图8示出了可以用来实施本公开的实施例的示例电子设备的示意性框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本公开的实现。
如图8所示,设备800包括计算单元801,其可以根据存储在只读存储器(ROM)802中的计算机程序或者从存储单元808加载到随机访问存储器(RAM)803中的计算机程序,来执行各种适当的动作和处理。在RAM 803中,还可存储设备800操作所需的各种程序和数据。计算单元801、ROM 802以及RAM 803通过总线804彼此相连。输入/输出(I/O)接口805也连接至总线804。
设备800中的多个部件连接至I/O接口805,包括:输入单元806,例如键盘、鼠标等;输出单元807,例如各种类型的显示器、扬声器等;存储单元808,例如磁盘、光盘等;以及通信单元809,例如网卡、调制解调器、无线通信收发机等。通信单元809允许设备800通过诸如因特网的计算机网络和/或各种电信网络与其他设备交换信息/数据。
计算单元801可以是各种具有处理和计算能力的通用和/或专用处理组件。计算单元801的一些示例包括但不限于中央处理单元(CPU)、图形处理单元(GPU)、各种专用的人工智能(AI)计算芯片、各种运行机器学习模型算法的计算单元、数字信号处理器(DSP)、以及任何适当的处理器、控制器、微控制器等。计算单元801执行上文所描述的各个方法和处理,例如量子电路处理方法。例如,在一些实施例中,量子电路处理方法可被实现为计算机软件程序,其被有形地包含于机器可读介质,例如存储单元808。在一些实施例中,计算机程序的部分或者全部可以经由ROM 802和/或通信单元809而被载入和/或安装到设备800上。当计算机程序加载到RAM 803并由计算单元801执行时,可以执行上文描述的量子电路处理方法的一个或多个步骤。备选地,在其他实施例中,计算单元801可以通过其他任何适当的方式(例如,借助于固件)而被配置为执行量子电路处理方法。
本文中以上描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、场可编程门阵列(FPGA)、专用集成电路(ASIC)、专用标准产品(ASSP)、芯片上系统的系统(SOC)、负载可编程逻辑设备(CPLD)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
用于实施本公开的方法的程序代码可以采用一个或多个编程语言的任何组合来编写。这些程序代码可以提供给通用计算机、专用计算机或其他可编程数据处理装置的处理器或控制器,使得程序代码当由处理器或控制器执行时使流程图和/或框图中所规定的功能/操作被实施。程序代码可以完全在机器上执行、部分地在机器上执行,作为独立软件包部分地在机器上执行且部分地在远程机器上执行或完全在远程机器或服务器上执行。
在本公开的上下文中,机器可读介质可以是有形的介质,其可以包含或存储以供指令执行系统、装置或设备使用或与指令执行系统、装置或设备结合地使用的程序。机器可读介质可以是机器可读信号介质或机器可读储存介质。机器可读介质可以包括但不限于电子的、磁性的、光学的、电磁的、红外的、或半导体系统、装置或设备,或者上述内容的任何合适组合。机器可读存储介质的更具体示例会包括基于一个或多个线的电气连接、便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦除可编程只读存储器(EPROM或快闪存储器)、光纤、便捷式紧凑盘只读存储器(CD-ROM)、光学储存设备、磁储存设备、或上述内容的任何合适组合。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)和互联网。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。服务器可以是云服务器,也可以为分布式系统的服务器,或者是结合了区块链的服务器。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本公开中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本公开公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本公开保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本公开的精神和原则之内所作的修改、等同替换和改进等,均应包含在本公开保护范围之内。
Claims (16)
1.一种量子电路处理方法,包括:
获取第一量子电路的第一指令列表;
基于所述第一指令列表,确定第一有向无环图,所述第一有向无环图包括所述第一指令列表中指令对应的节点和至少两个第一有向边,所述第一有向边用于表征所述第一指令列表中不同指令间的时序关系,所述至少两个第一有向边构成的路径不包括有向环路;
基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,所述第二有向无环图包括第二有向边和所述至少两个第一有向边,所述第二有向边和所述至少两个第一有向边构成的路径不包括有向环路,所述输入节点列表包括所述第一指令列表中类型为重置操作指令对应的节点,所述输出节点列表包括所述第一指令列表中类型为量子测量操作指令对应的节点,所述第二有向边为所述输出节点列表中输出节点与所述输入节点列表中输入节点的有向边,所述第二有向无环图中,每个输出节点至多与一个输入节点相连,不同输出节点不能与同一个输入节点相连;
基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
2.根据权利要求1所述的方法,其中,所述基于所述第一指令列表,确定第一有向无环图,包括:
对所述第一指令列表按照从左至右的指令排列顺序进行遍历,并获取第二目标列表和当前遍历的指令所作用的第一量子位,所述第二目标列表包括所述第一指令列表中排序在所述当前遍历的指令之前的指令;
对所述第二目标列表按照从右至左的指令排列顺序进行遍历,并获取第一目标指令,所述第一目标指令所作用的量子位与所述第一量子位存在交集;
将所述第一目标指令的标识作为源节点,所述当前遍历的指令的标识作为目标节点,构建所述第一有向边;
在所述第一指令列表遍历完成的情况下,基于所构建的第一有向边,获取所述第一有向无环图。
3.根据权利要求1所述的方法,其中,所述基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,包括:
针对所述输出节点列表中每个输出节点,获取所述输出节点对应的第一集合,在基于所述第一有向无环图确定所述输入节点列表中存在无法到达所述输出节点的目标输入节点的情况下,所述第一集合包括所述目标输入节点;
将各输出节点对应的所述第一集合进行笛卡尔积,得到包括目标可行解的第二集合,所述目标可行解指示各输出节点可进行连接的输入节点,所述目标可行解中用于指示输入节点的标识不可重复;
基于所述第二集合,在所述第一有向无环图中构建所述第二有向边,得到所述第二有向无环图。
4.根据权利要求3所述的方法,其中,所述基于所述第二集合,在所述第一有向无环图中构建第二有向边,得到所述第二有向无环图,包括:
基于所述目标可行解中用于指示输入节点的标识的数量,对所述第二集合中的目标可行解进行排序,得到第三目标列表,所述第三目标列表中,第一目标可行解排序在第二目标可行解之前,所述第一目标可行解中用于指示输入节点的标识的数量大于所述第二目标可行解中用于指示输入节点的标识的数量;
对所述第三目标列表按照从左至右的排列顺序进行遍历,基于当前遍历的目标可行解,在所述第一有向无环图中构建有向边,得到目标有向图;
在确定所述目标有向图中有向边所构成的路径不包括有向环路的情况下,将在所述第一有向无环图构建的有向边确定为所述第二有向边,并将所述目标有向图确定为所述第二有向无环图。
5.根据权利要求1所述的方法,其中,所述基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表,包括:
基于所述第二有向无环图,对所述第一指令列表中的指令进行重排序,得到第三指令列表;
基于所述第一目标列表,对所述第三指令列表中的指令进行等效编译,得到所述第二指令列表。
6.根据权利要求5所述的方法,其中,所述基于所述第二有向无环图,对所述第一指令列表中的指令进行重排序,得到第三指令列表,包括:
获取所述第二有向无环图对应的拓扑排序列表,所述拓扑排序列表中,针对所述第二有向无环图中的每个有向边,所述有向边的源节点排序在所述有向边的目标节点之前;
基于所述拓扑排序列表,对所述第一指令列表中的指令进行重排序,得到所述第三指令列表。
7.根据权利要求5所述的方法,其中,所述基于所述第一目标列表,对所述第三指令列表中的指令进行等效编译,得到所述第二指令列表,包括:
针对所述第一目标列表中每个所述第二有向边,对所述第三指令列表中各第二目标指令所作用的第二量子位更新为第三量子位,所述第二量子位为所述第二有向边中目标节点对应指令所作用的量子位,所述第三量子位为所述第二有向边中源节点对应指令所作用的量子位。
8.一种量子电路处理装置,包括:
获取模块,用于获取第一量子电路的第一指令列表;
第一确定模块,用于基于所述第一指令列表,确定第一有向无环图,所述第一有向无环图包括所述第一指令列表中指令对应的节点和至少两个第一有向边,所述第一有向边用于表征所述第一指令列表中不同指令间的时序关系,所述至少两个第一有向边构成的路径不包括有向环路;
第二确定模块,用于基于所述第一有向无环图、以及所述第一有向无环图的输入节点列表和输出节点列表,确定第二有向无环图,所述第二有向无环图包括第二有向边和所述至少两个第一有向边,所述第二有向边和所述至少两个第一有向边构成的路径不包括有向环路,所述输入节点列表包括所述第一指令列表中类型为重置操作指令对应的节点,所述输出节点列表包括所述第一指令列表中类型为量子测量操作指令对应的节点,所述第二有向边为所述输出节点列表中输出节点与所述输入节点列表中输入节点的有向边,所述第二有向无环图中,每个输出节点至多与一个输入节点相连,不同输出节点不能与同一个输入节点相连;
等效编译模块,用于基于所述第二有向无环图、所述第二有向边构成的第一目标列表和所述第一指令列表,对所述第一量子电路进行等效编译,得到与所述第一量子电路等效的第二量子电路的第二指令列表。
9.根据权利要求8所述的装置,其中,所述第一确定模块,具体用于:
对所述第一指令列表按照从左至右的指令排列顺序进行遍历,并获取第二目标列表和当前遍历的指令所作用的第一量子位,所述第二目标列表包括所述第一指令列表中排序在所述当前遍历的指令之前的指令;
对所述第二目标列表按照从右至左的指令排列顺序进行遍历,并获取第一目标指令,所述第一目标指令所作用的量子位与所述第一量子位存在交集;
将所述第一目标指令的标识作为源节点,所述当前遍历的指令的标识作为目标节点,构建所述第一有向边;
在所述第一指令列表遍历完成的情况下,基于所构建的第一有向边,获取所述第一有向无环图。
10.根据权利要求8所述的装置,其中,所述第二确定模块包括:
获取单元,用于针对所述输出节点列表中每个输出节点,获取所述输出节点对应的第一集合,在基于所述第一有向无环图确定所述输入节点列表中存在无法到达所述输出节点的目标输入节点的情况下,所述第一集合包括所述目标输入节点;
笛卡尔积单元,用于将各输出节点对应的所述第一集合进行笛卡尔积,得到包括目标可行解的第二集合,所述目标可行解指示各输出节点可进行连接的输入节点,所述目标可行解中用于指示输入节点的标识不可重复;
构建单元,用于基于所述第二集合,在所述第一有向无环图中构建所述第二有向边,得到所述第二有向无环图。
11.根据权利要求10所述的装置,其中,所述构建单元,具体用于:
基于所述目标可行解中用于指示输入节点的标识的数量,对所述第二集合中的目标可行解进行排序,得到第三目标列表,所述第三目标列表中,第一目标可行解排序在第二目标可行解之前,所述第一目标可行解中用于指示输入节点的标识的数量大于所述第二目标可行解中用于指示输入节点的标识的数量;
对所述第三目标列表按照从左至右的排列顺序进行遍历,基于当前遍历的目标可行解,在所述第一有向无环图中构建有向边,得到目标有向图;
在确定所述目标有向图中有向边所构成的路径不包括有向环路的情况下,将在所述第一有向无环图构建的有向边确定为所述第二有向边,并将所述目标有向图确定为所述第二有向无环图。
12.根据权利要求8所述的装置,其中,所述等效编译模块包括:
重排序单元,用于基于所述第二有向无环图,对所述第一指令列表中的指令进行重排序,得到第三指令列表;
等效编译单元,用于基于所述第一目标列表,对所述第三指令列表中的指令进行等效编译,得到所述第二指令列表。
13.根据权利要求12所述的装置,其中,所述重排序单元,具体用于:
获取所述第二有向无环图对应的拓扑排序列表,所述拓扑排序列表中,针对所述第二有向无环图中的每个有向边,所述有向边的源节点排序在所述有向边的目标节点之前;
基于所述拓扑排序列表,对所述第一指令列表中的指令进行重排序,得到所述第三指令列表。
14.根据权利要求12所述的装置,其中,所述等效编译单元,具体用于:
针对所述第一目标列表中每个所述第二有向边,对所述第三指令列表中各第二目标指令所作用的第二量子位更新为第三量子位,所述第二量子位为所述第二有向边中目标节点对应指令所作用的量子位,所述第三量子位为所述第二有向边中源节点对应指令所作用的量子位。
15.一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-7中任一项所述的方法。
16.一种存储有计算机指令的非瞬时计算机可读存储介质,其中,所述计算机指令用于使所述计算机执行根据权利要求1-7中任一项所述的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310158747.9A CN116151384B (zh) | 2023-02-20 | 2023-02-20 | 量子电路处理方法、装置及电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202310158747.9A CN116151384B (zh) | 2023-02-20 | 2023-02-20 | 量子电路处理方法、装置及电子设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN116151384A CN116151384A (zh) | 2023-05-23 |
CN116151384B true CN116151384B (zh) | 2023-09-08 |
Family
ID=86354116
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202310158747.9A Active CN116151384B (zh) | 2023-02-20 | 2023-02-20 | 量子电路处理方法、装置及电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN116151384B (zh) |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN116757291B (zh) * | 2023-06-15 | 2024-09-20 | 北京百度网讯科技有限公司 | 量子电路的分布式处理方法、装置及电子设备 |
CN116629370B (zh) * | 2023-06-26 | 2024-05-24 | 北京百度网讯科技有限公司 | 量子电路处理方法、装置及电子设备 |
CN117313879A (zh) * | 2023-09-27 | 2023-12-29 | 北京百度网讯科技有限公司 | 量子电路处理方法、装置及电子设备 |
CN117313883B (zh) * | 2023-09-27 | 2025-01-28 | 北京百度网讯科技有限公司 | 量子电路处理方法、装置及电子设备 |
CN117313878B (zh) * | 2023-09-27 | 2024-12-10 | 北京百度网讯科技有限公司 | 量子电路处理方法、装置及电子设备 |
CN117744813A (zh) * | 2023-12-20 | 2024-03-22 | 北京百度网讯科技有限公司 | 量子电路处理方法、装置及电子设备 |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110889507A (zh) * | 2019-12-11 | 2020-03-17 | 合肥本源量子计算科技有限责任公司 | 一种量子程序转有向无环图的方法、装置、存储介质及电子装置 |
CN110929873A (zh) * | 2019-12-11 | 2020-03-27 | 合肥本源量子计算科技有限责任公司 | 一种量子程序的处理方法、装置、存储介质和电子装置 |
CN111027702A (zh) * | 2019-12-11 | 2020-04-17 | 合肥本源量子计算科技有限责任公司 | 一种实现量子线路替换的方法、装置、存储介质和电子装置 |
CN113537502A (zh) * | 2021-07-14 | 2021-10-22 | 北京百度网讯科技有限公司 | 量子电路的处理方法、装置、电子设备和存储介质 |
CN114841352A (zh) * | 2022-05-11 | 2022-08-02 | 北京百度网讯科技有限公司 | 量子计算处理方法、装置及电子设备 |
CN114881237A (zh) * | 2022-03-29 | 2022-08-09 | 北京百度网讯科技有限公司 | 量子计算处理方法、装置及电子设备 |
CN115169570A (zh) * | 2022-07-26 | 2022-10-11 | 北京百度网讯科技有限公司 | 量子网络协议仿真方法、装置及电子设备 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11983600B2 (en) * | 2020-12-14 | 2024-05-14 | International Business Machines Corporation | Compilation of a quantum program |
-
2023
- 2023-02-20 CN CN202310158747.9A patent/CN116151384B/zh active Active
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110889507A (zh) * | 2019-12-11 | 2020-03-17 | 合肥本源量子计算科技有限责任公司 | 一种量子程序转有向无环图的方法、装置、存储介质及电子装置 |
CN110929873A (zh) * | 2019-12-11 | 2020-03-27 | 合肥本源量子计算科技有限责任公司 | 一种量子程序的处理方法、装置、存储介质和电子装置 |
CN111027702A (zh) * | 2019-12-11 | 2020-04-17 | 合肥本源量子计算科技有限责任公司 | 一种实现量子线路替换的方法、装置、存储介质和电子装置 |
CN113537502A (zh) * | 2021-07-14 | 2021-10-22 | 北京百度网讯科技有限公司 | 量子电路的处理方法、装置、电子设备和存储介质 |
CN114881237A (zh) * | 2022-03-29 | 2022-08-09 | 北京百度网讯科技有限公司 | 量子计算处理方法、装置及电子设备 |
CN114841352A (zh) * | 2022-05-11 | 2022-08-02 | 北京百度网讯科技有限公司 | 量子计算处理方法、装置及电子设备 |
CN115169570A (zh) * | 2022-07-26 | 2022-10-11 | 北京百度网讯科技有限公司 | 量子网络协议仿真方法、装置及电子设备 |
Non-Patent Citations (1)
Title |
---|
基于复合域SM4 密码算法S盒的量子电路实现;罗庆斌等;电子科技大学学报;第51卷(第6期);812-818 * |
Also Published As
Publication number | Publication date |
---|---|
CN116151384A (zh) | 2023-05-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN116151384B (zh) | 量子电路处理方法、装置及电子设备 | |
CN116151381B (zh) | 量子电路处理方法、装置及电子设备 | |
CN116187458B (zh) | 量子电路处理方法、装置及电子设备 | |
CN115169570B (zh) | 量子网络协议仿真方法、装置及电子设备 | |
CN116611527B (zh) | 量子电路处理方法、装置及电子设备 | |
CN115860128B (zh) | 量子电路运行方法、装置及电子设备 | |
CN116167446B (zh) | 量子计算处理方法、装置及电子设备 | |
CN116579435B (zh) | 量子电路的分类方法、装置、电子设备、介质和产品 | |
CN114580645B (zh) | 随机量子测量的模拟方法、装置、设备及存储介质 | |
CN116187463B (zh) | 量子测量模式至量子电路的编译方法、装置及电子设备 | |
CN116167445B (zh) | 量子测量模式的处理方法、装置及电子设备 | |
CN116227607B (zh) | 量子电路的分类方法、装置、电子设备、介质和产品 | |
CN116629370B (zh) | 量子电路处理方法、装置及电子设备 | |
CN114611609A (zh) | 一种图网络模型节点分类方法、装置、设备及存储介质 | |
CN116187464B (zh) | 盲量子计算处理方法、装置及电子设备 | |
CN118690837A (zh) | 算子融合方法、装置及电子设备 | |
CN116974249A (zh) | 柔性作业车间调度方法和柔性作业车间调度装置 | |
CN116167447B (zh) | 量子电路处理方法、装置及电子设备 | |
CN117391206B (zh) | 量子电路处理方法、装置及电子设备 | |
CN117313878B (zh) | 量子电路处理方法、装置及电子设备 | |
CN117313883B (zh) | 量子电路处理方法、装置及电子设备 | |
CN117313881B (zh) | 量子电路的分类方法、装置及电子设备 | |
CN112580803B (zh) | 模型获取方法、装置、电子设备、存储介质和程序产品 | |
CN117313882A (zh) | 量子电路处理方法、装置及电子设备 | |
CN116151383B (zh) | 量子计算处理方法、装置及电子设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant | ||
REG | Reference to a national code |
Ref country code: HK Ref legal event code: DE Ref document number: 40088454 Country of ref document: HK |