The present embodiment relates to a quantum circuit design program, a quantum circuit design method, and a quantum circuit design device.
There is a quantum computer that executes calculation faster than a classical computer using quantum properties. A quantum computer based on a quantum gate system performs quantum calculation by performing a gate operation on qubits in order indicated in a quantum circuit.
Related art is disclosed in Japanese National Publication of International Patent Application No. 2021-503116, Japanese National Publication of International Patent Application No. 2003-526855 and Dmitri Maslov, “Basic circuit compilation techniques for an ion-trap quantum Machine” New Journal of Physics, Volume 19, February 2017.
According to an aspect of the embodiments, a non-transitory computer-readable recording medium stores a quantum circuit design program for causing a computer to execute processing including: detecting, from a first quantum circuit that is a quantum circuit that includes a plurality of elements and that indicates operation order on each of a plurality of qubits included in a quantum computer by arrangement of each of the plurality of elements in the quantum circuit, a first element that indicates a predetermined operation on a plurality of first qubits among the plurality of qubits and a second element that indicates the predetermined operation on the plurality of first qubits; and generating a second quantum circuit obtained by converting the first element of the first quantum circuit into a first equivalent circuit for ion operation that corresponds to the plurality of first qubits and converting the second element into a second equivalent circuit arranged by symmetrically moving elements of the first equivalent circuit in an arrangement direction of the plurality of first qubits.
The object and advantages of the invention will be realized and attained by means of the elements and combinations particularly pointed out in the claims.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory and are not restrictive of the invention.
Examples of quantum algorithm executed by the quantum computer based on the quantum gate system include Grover's algorithm for searching data. For example, in a case where one piece of data is searched for from N pieces of data (N is a natural number), an average number of arithmetic operations by a classical computer is N/2, whereas the data may be searched for in N1/2 arithmetic operations according to the Grover's algorithm.
As a technology related to a quantum computer, for example, automated methods for optimizing quantum circuits of a size and type expected in quantum calculation have been proposed. Furthermore, a technology related to a random interference gate that performs a random interference operation on a vector of an input set according to Grover's quantum search algorithm has also been proposed. Moreover, a technology of compilation of quantum algorithm into optimized physical-level circuits executable in a quantum information processing experiment using atomic ions has also been proposed.
A qubit is implemented by using, for example, superconductivity, an ion trap, or the like. Furthermore, in a gate operation on the qubit, for example, a quantum computer irradiates the qubit with a microwave. An error may occur in quantum calculation due to noise included in such a gate operation on the qubit.
In one aspect, an object of the present invention is to reduce an error in quantum calculation.
Hereinafter, the present embodiments will be described with reference to the drawings. Note that each of the embodiments may be implemented in combination with a plurality of embodiments as long as no contradiction arises.
First, a first embodiment will be described. The first embodiment is a quantum circuit design method capable of reducing an error in quantum calculation in an ion trap quantum computer.
The quantum circuit design device 10 includes a processing unit 11. The processing unit 11 is, for example, a processor or an arithmetic circuit included in the quantum circuit design device 10. The processing unit 11 generates a second quantum circuit obtained by converting elements included in a first quantum circuit 1. The first quantum circuit 1 is a quantum circuit including a plurality of elements, and indicates operation order for each of qubits q0, q1, and q2 by arrangement of each of the plurality of elements in the quantum circuit. For example, the first quantum circuit 1 has lines corresponding to the respective qubits q0, q1, and q2. In the first quantum circuit 1, the line corresponding to the qubit q0, the line corresponding to the qubit q1, and the line corresponding to the qubit q2 are arranged in order from the top. On each line included in the first quantum circuit 1, an element indicating an operation on a quantum state of the corresponding qubit is arranged. In the first quantum circuit 1, an element indicating an operation performed earlier is arranged on the left.
Examples of the elements arranged in the first quantum circuit 1 include an H gate, an X gate, a CCZ gate, measurement, and the like. Here, the CCZ gate is arranged by setting two control bits and one target bit. The CCZ gate indicates that, in a case where the two control bits are “1”, a Z gate is acted (phase is inverted) on the one target bit. Note that the CCZ gate is equivalent no matter which combination of the two control bits and the one target bit is set from the three qubits.
The processing unit 11 detects a first element 1a indicating a predetermined operation and a second element 1b indicating the predetermined operation on a plurality of first qubits among the qubits q0, q1, and q2 included in the first quantum circuit 1. Here, the predetermined operation is an operation of inverting a phase of one target bit among the qubits q0, q1, and q2 according to two control bits among the three qubits q0, q1, and q2. That is, the processing unit 11 detects two CCZ gates for the qubits q0, q1, and q2.
Then, the processing unit 11 generates the second quantum circuit obtained by converting the first element 1a into a first equivalent circuit 2 in the first quantum circuit 1 and converting the second element 1b into a second equivalent circuit 3 arranged by symmetrically moving elements of the first equivalent circuit 2 in an arrangement direction of the plurality of first qubits. Quantum gates included in the first equivalent circuit 2 are two-qubit gates 2a to 2e or a one-qubit gate. Similarly, quantum gates included in the second equivalent circuit 3 are two-qubit gates 3a to 3e or a one-qubit gate. Since the number of qubits to be operated of each quantum gate in the first equivalent circuit 2 and the second equivalent circuit 3 is equal to or less than two, the qubits may be operated according to each of the first equivalent circuit 2 and the second equivalent circuit 3.
The first equivalent circuit 2 is an equivalent circuit for ion operation corresponding to qubits in the ion trap quantum computer. For the ion operation corresponding to the qubits in the ion trap quantum computer, an XX gate is used. The XX gate is a gate indicating an operation of simultaneously rotating states of two qubits by a predetermined angle around an X axis.
For example, the processing unit 11 converts the CCZ gate for the qubits q0, q1, and q2 included in the first quantum circuit 1 into the first equivalent circuit 2 that is a combination of the XX gate, an Rx gate, an Ry gate, an Rz gate, a T gate, and a T† gate and is equivalent to the CCZ gate. The Rx gate is a gate indicating an operation of causing rotation by an optional angle around the X axis. The Ry gate is a gate indicating an operation of causing rotation by an optional angle around a Y axis. The Rz gate is a gate indicating an operation of causing rotation by an optional angle around a Z axis. The T gate is a gate indicating an operation of causing rotation of 45 degrees around the Z axis. The T† gate is a gate indicating a rotation operation in which a rotation direction of the T gate is set to an opposite direction.
Furthermore, the processing unit 11 converts the CCZ gate for the qubits q0, q1, and q2, which is included in the first quantum circuit 1 and is different from the CCZ gate converted into the first equivalent circuit 2, into the second equivalent circuit 3 arranged by symmetrically moving the elements of the first equivalent circuit 2 with the line corresponding to the qubit q1 as an axis.
As described above, the processing unit 11 detects the gates (the first element 1a and the second element 1b) indicating the predetermined operation on the plurality of first qubits among the qubits q0, q1, and q2 included in the first quantum circuit 1 indicating the operation order on each of the qubits q0, q1, and q2 by the arrangement of the elements. Then, the processing unit 11 generates the second quantum circuit obtained by converting the first element 1a into the first equivalent circuit 2 in the first quantum circuit 1 and converting the second element 1b into the second equivalent circuit 3 arranged by symmetrically moving the elements of the first equivalent circuit 2 in the arrangement direction of the plurality of first qubits.
In quantum calculation, an error may occur in each qubit due to noise included in a gate operation on a qubit. Therefore, when the number of gate operations for each qubit is biased, an error is likely to occur in a qubit having a large number of gate operations. In the second quantum circuit, since the second equivalent circuit 3 is arranged by symmetrically moving the elements of the first equivalent circuit 2 in the arrangement direction of the plurality of first qubits, the number of gate operations for each qubit is less biased. Therefore, the ion trap quantum computer operates qubits according to the second quantum circuit, so that a bias of the qubits affected by noise may be reduced. Therefore, the quantum circuit design device 10 may reduce an error in the quantum calculation.
Furthermore, the predetermined operation is the operation of inverting, according to two control bits among three first qubits, a phase of one target bit among the first qubits. The predetermined operation is, for example, the CCZ gate. As a result, the quantum circuit design device 10 may reduce an error in quantum calculation including the CCZ gate.
Note that the processing unit 11 may convert a third element that inverts, according to two control bits among the first qubits, a bit of one target bit among the first qubits into a third equivalent circuit including the predetermined operation. The third element is, for example, a CCX gate. As a result, the quantum circuit design device 10 may reduce an error in quantum calculation including the CCX gate.
Furthermore, the processing unit 11 may convert a fourth element that inverts, according to equal to or more than three control bits of second qubits including the first qubits, a bit of one target bit of the second qubits into a fourth equivalent circuit including the third element. The fourth element is, for example, a CnNOT gate. As a result, the quantum circuit design device 10 may reduce an error in the quantum calculation including the CnNOT gate.
Next, a second embodiment will be described. The second embodiment is a system in which an ion trap quantum computer performs quantum calculation according to a quantum circuit.
The control computer 100 instructs the qubit control device 200 to control qubits according to the quantum circuits received from the terminal devices 31, 32, . . . . Furthermore, the control computer 100 acquires a measurement result of each qubit from the qubit control device 200.
The qubit control device 200 includes a plurality of qubits and a device for operating each of the plurality of qubits. For example, the qubit control device 200 includes a laser signal generation device 210 and a dilution refrigerator 220. The laser signal generation device 210 outputs a plurality of laser beams 223 according to an instruction from the control computer 100. The dilution refrigerator 220 confines a plurality of ions (charged particles) 222 using an electromagnetic field in a free space. The dilution refrigerator 220 maintains a state where the plurality of ions 222 is cooled to a very low temperature. Each of the plurality of ions 222 is irradiated with the laser beam 223 output from the laser signal generation device 210. A state of each of the plurality of ions 222 is observed by a photodetector 221 provided in the dilution refrigerator 220.
Each of the plurality of ions 222 corresponds to a qubit, and the state of each of the plurality of ions 222 represents a state of the corresponding qubit. When the state of each of the plurality of qubits is measured, the qubit control device 200 transmits a measurement result to the control computer 100.
The RAM 102 is a main storage device of the control computer 100. In the RAM 102, at least a part of an operating system (OS) program or an application program to be executed by the CPU 101 is temporarily stored. Furthermore, in the RAM 102, various types of data to be used in processing by the CPU 101 are stored. Note that the control computer 100 may include a memory of a type other than the RAM, or may include a plurality of memories.
Examples of the peripheral devices coupled to the bus 110 include a hard disk drive (HDD) 103, a graphics processing unit (GPU) 104, an input interface 105, an optical drive device 106, device coupling interfaces 107 and 108, and a network interface 109.
The HDD 103 is an auxiliary storage device of the control computer 100. The HDD 103 magnetically writes data to and reads data from a built-in magnetic disk. In the HDD 103, an OS program, an application program, and various types of data are stored. Note that the control computer 100 may include other types of auxiliary storage devices such as a flash memory and a solid state drive (SSD), or may include a plurality of auxiliary storage devices.
A monitor 21 is coupled to the GPU 104. The GPU 104 displays an image on a screen of the monitor 21 according to a command from the CPU 101. Examples of the monitor 21 include a display device using organic electro luminescence (EL), a liquid crystal display device, and the like.
A keyboard 22 and a mouse 23 are coupled to the input interface 105. The input interface 105 transmits signals transmitted from the keyboard 22 and the mouse 23 to the CPU 101. Note that the mouse 23 is an example of a pointing device, and another pointing device may also be used. Examples of the another pointing device include a touch panel, a tablet, a touch pad, a track ball, and the like.
The optical drive device 106 reads data recorded in an optical disk 24 by using a laser beam or the like. The optical disk 24 is a portable recording medium in which data is recorded in a manner readable by reflection of light. Examples of the optical disk 24 include a digital versatile disc (DVD), a DVD-RAM, a compact disc read only memory (CD-ROM), a CD-recordable (R)/rewritable (RW), and the like.
The device coupling interface 107 is a communication interface for coupling the peripheral devices to the control computer 100. For example, a memory device 25 and a memory reader/writer 26 may be coupled to the device coupling interface 107. The memory device 25 is a recording medium equipped with a communication function with the device coupling interface 107. The memory reader/writer 26 is a device that writes data to a memory card 27 or reads data from the memory card 27. The memory card 27 is a card type recording medium.
The device coupling interface 108 is a communication interface for coupling the qubit control device 200 to the control computer 100. The control computer 100 transmits an instruction for controlling qubits to the qubit control device 200 via the device coupling interface 108.
The network interface 109 is coupled to the network 20. The network interface 109 exchanges data with another computer or communication device via the network 20.
The control computer 100 may implement processing functions of the second embodiment with the hardware configuration as described above. Note that the quantum circuit design device 10 indicated in the first embodiment may also be implemented by hardware similar to that of the control computer 100 illustrated in
The control computer 100 implements the processing functions of the second embodiment by executing, for example, a program recorded in a computer-readable recording medium. A program in which processing content to be executed by the control computer 100 is described may be recorded in various recording media. For example, the program to be executed by the control computer 100 may be stored in the HDD 103. The CPU 101 loads at least a part of the programs in the HDD 103 into the RAM 102, and executes the loaded program. Furthermore, the program to be executed by the control computer 100 may also be recorded in a portable recording medium such as the optical disk 24, the memory device 25, or the memory card 27. For example, the program stored in the portable recording medium may be executed after being installed to the HDD 103 under the control of the CPU 101. Furthermore, the CPU 101 may directly read and execute the program from the portable recording medium.
In the second embodiment, the quantum computer 300 executes quantum calculation. Examples of quantum algorithm executable by the quantum computer 300 include Grover's algorithm.
A graph 41 illustrates a probability amplitude of each of the ground states x1 to x4 in a superposed state of the ground states x1, x2, x3, and x4. Note that the ground states x1 to x4 each correspond to data to be searched for. In the graph 41, the probability amplitude of each of the ground states x1 to x4 is N−1/2.
An oracle Uf is applied in inversion processing of the Grover's algorithm. The oracle Uf is indicated by the following Expression (1).
In Expression (1), x indicates each ground state. Furthermore, in Expression (1), v is a ground state corresponding to the correct answer data. Furthermore, f(x) in Expression (1) is a function that satisfies f(v)=1 and f(x)=0 when x is other than v. Furthermore, in Expression (1), I is an identity matrix of N rows and N columns.
A graph 42 illustrates a probability amplitude of each of the ground states x1 to x4 in a case where the oracle Uf is applied to the superposed state of the ground states x1 to x4 illustrated in the graph 41. Note that the ground state corresponding to the correct answer data is assumed to be the ground state x3. In the graph 42, a sign of the probability amplitude is inverted with respect to the graph 41 only in the ground state x3 among the ground states x1 to x4.
In the amplification processing of the Grover's algorithm, −W indicated by the following Expression (2) is applied.
In Expression (2), w indicates a superposed state of all the states. A graph 43 illustrates a probability amplitude of each of the ground states x1 to x4 in a case where −W is applied to the state illustrated in the graph 42. In the graph 43, the probability amplitudes of the ground states x1 to x4 are inverted around an average value with respect to the graph 42. By such inversion amplification processing, the probability amplitude of the ground state x3 corresponding to the correct answer data becomes larger than that of the ground states x1, x2, and x4.
Next, a specific example in which the Grover's algorithm as described above is executed with three qubits will be described. A superposed state |ψ> of states indicated by the three qubits is indicated by the following Expression (3).
Expression (3) indicates that, for each of the three qubits, a probability amplitude of being in a state “0” and a probability amplitude of being in a state “1” are 2−1/2. Furthermore, Expression (3) indicates that a probability amplitude of each of states “000” to “111” indicated by the three qubits is 8−1/2. Here, when a state “010” is assumed to correspond to the correct answer data, a state Uf|ψ> to which the oracle Uf is applied is indicated by the following Expression (4).
Expression (4) indicates that, among the states “000” to “111”, a probability amplitude of the state “010” is −8−1/2, and probability amplitudes of the states other than the state “010” are 8−1/2. That is, Expression (4) indicates a state where a sign of the probability amplitude of the state “010” is inverted from the state indicated by Expression (3). Furthermore, an average value of the probability amplitude in the state Uf|ψ> is indicated by the following Expression (5).
A state −WUf|ψ> where −W is applied to the state Uf|ψ> is indicated by the following Expression (6).
Expression (6) indicates a state where the probability amplitudes of the states “000” to “111” are inverted around the average value of the probability amplitude indicated by Expression (5) from the state represented by Expression (4). A probability of becoming the state “010” in the state −WUf|ψ> is a square of the probability amplitude, and thus is indicated by the following Expression (7).
As described above, when −WUf is applied to the superposed state |ψ> of the states “000” to “111”, the probability of becoming the state “010” increases to 0.781 from 0.125, which is a probability of randomly becoming one of the eight states. Note that when −WUf is applied twice to the state |ψ>, the probability of becoming the state “010” is 0.945.
Next, a quantum circuit for causing the quantum computer 300 to execute the Grover's algorithm will be described.
In the quantum circuit 50, each of blocks described as H arranged on the lines corresponding to the respective qubits q0, q1, and q2 indicates an H gate (Hadamard gate). The H gate indicates an operation of creating a superposed state. Furthermore, in the quantum circuit 50, each of blocks described as X arranged on the lines corresponding to the respective qubits q0, q1, and q2 indicates an X gate. The X gate indicates an operation of inverting a bit of a qubit corresponding to an arranged line.
Furthermore, in the quantum circuit 50, each of blocks described as Z arranged on the lines corresponding to the respective qubits q0, q1, and q2 and two points coupled to the block described as Z by a line and arranged on the lines corresponding to the respective qubits q0, q1, and q2 indicate a CCZ gate. Note that the block described as Z is arranged on a line corresponding to a qubit to be a target bit of the CCZ gate, and the two points are arranged on lines corresponding to the respective qubits to be two control bits of the CCZ gate. The CCZ gate indicates that, in a case where the two control bits are “1”, a Z gate is acted (phase is inverted) on the one target bit.
Note that the CCZ gate is equivalent no matter which combination of the two control bits and the one target bit is set from the three qubits. That is, the CCZ gate in which the qubits q1 and q2 are the control bits and the qubit q0 is the target bit may be replaced with a CCZ gate in which the qubits q0 and q2 are the control bits and the qubit q1 is the target bit. Furthermore, the CCZ gate in which the qubits q1 and q2 are the control bits and the qubit q0 is the target bit may be replaced with a CCZ gate in which the qubits q0 and q1 are the control bits and the qubit q2 is the target bit. Hereinafter, the CCZ gate in which the two control bits and the one target bit are set from the qubits q0, q1, and q2 may be referred to as the CCZ gate for the qubits q0, q1, and q2.
In the quantum circuit 50, each of blocks arranged on the lines corresponding to the respective qubits q0, q1, and q2, in which a figure obtained by combining a semicircular arc and a straight line is described, indicates measurement. By the measurement, each of the qubits q0, q1, and q2 is determined to be the state of “0” or “1”.
The H gate for each of the qubits q0, q1, and q2 is arranged at a left end of the quantum circuit 50. As a first operation indicated by the quantum circuit 50, the H gate is acted on each of the qubits q0, q1, and q2, so that the qubits q0, q1, and q2 are in the superposed state indicated by Expression (3) (initialized). Furthermore, in the quantum circuit 50, a combination of the X gates and the CCZ gate indicating processing of applying the oracle is arranged on the right side of the H gates indicating initialization. Furthermore, in the quantum circuit 50, a combination of the H gates, the X gates, and the CCZ gate indicating the amplification processing is arranged on the right side of the combination of the gates indicating the oracle. Furthermore, in the quantum circuit 50, observation for each of the qubits q0, q1, and q2 is arranged on the right side of the combination of the gates indicating the amplification processing. By the observation indicated in the quantum circuit 50, a result of performing the inversion amplification processing of the Grover's algorithm once is output.
Note that the quantum computer 300 may include a device that performs a gate operation on equal to or smaller than two qubits, and may not have the device that may perform a gate operation on equal to or more than three qubits. Thus, a gate for three qubits such as the CCZ gate is converted into an equivalent circuit obtained by combining gates for two qubits or one qubit.
Furthermore, in the equivalent circuit 51, each of symbols obtained by combining + and a circle arranged on the lines corresponding to the respective qubits q0, q1, and q2, and a point coupled to the symbol by a line and arranged on the line corresponding to one of the respective qubits q0, q1, and q2 indicate a CNOT gate. Note that the symbol obtained by combining + and the circle is arranged on a line corresponding to a qubit to be a target bit of the CNOT gate, and the point is arranged on a line corresponding to a qubit to be a control bit of the CNOT gate. The CNOT gate indicates that a bit of the target bit is inverted in a case where the control bit is “1”.
As described above, the CCZ gate may be converted into the equivalent circuit 51 obtained by combining the gates for two qubits or one qubit. Note that the equivalent circuit 51 illustrated in
On the other hand, the XX gate is represented by the following Expression (9).
By using the XX gate, an equivalent circuit 60 of the CX gate may be created. A value of χ of the XX gate in that case is “π/4”. In the equivalent circuit 60, a block described as RX indicates a rotation operation of a Bloch sphere around the X axis. Each of blocks described as RY indicates a rotation operation of the Bloch sphere around a Y axis. A block described as RZ indicates a rotation operation of the Bloch sphere around a Z axis. An angle (±π/2) described in each block is a rotation angle around each axis.
In the equivalent circuit 60, a block across two qubits is the XX gate. In the XX gate, the qubit described as “0” corresponds to a control bit in the CX gate, and the qubit described as “1” corresponds to a target bit in the CX gate. An angle described in the block indicating the XX gate is a rotation angle of the two qubits to be operated. In the case of the equivalent circuit 60 of the CX gate, the rotation angle by the XX gate is π/2. A value obtained by dividing the rotation angle by 2 is the value of χ in Expression (9) of the XX gate.
By using such an XX gate, an equivalent circuit applicable to the ion trap quantum computer may also be generated for the CCZ gate.
In a case where the ion trap quantum computer 300 executes the processing indicated by the quantum circuit 50, it is conceivable that the control computer 100 generates a quantum circuit obtained by converting each of the two CCZ gates included in the quantum circuit 50 into the equivalent circuit 61. Then, it is conceivable that the control computer 100 instructs the qubit control device 200 to control qubits according to the generated quantum circuit.
Here, in quantum calculation by the quantum computer 300, an error may occur in each qubit due to noise included in a gate operation. Examples of the errors in the qubits include an error due to interference with an external environment (stochastic Pauli, depolarization, amplitude damping, or phase damping) and an error that occurs only inside (coherent error). The coherent error is an error due to defective implementation of a quantum gate, and it is difficult to completely remove the coherent error. The coherent error includes a one-qubit error and a two-qubit error. In an actual device, a probability of occurrence of the two-qubit error is larger than that of the one-qubit error by about 10. Therefore, an influence of the two-qubit error on the entire error is larger than that of the one-qubit error.
Therefore, in a case where the two CCZ gates included in the quantum circuit 50 are converted into the equivalent circuits 61, an error is likely to occur in a qubit having a large number of gate operations in the equivalent circuits 61. For example, in the equivalent circuit 61 illustrated in
In all of each line of the graph 81, a probability in the case of no noise is “0.781”. In each line, as the noise increases, a difference from the probability “0.781” in the case of no noise increases. A degree of the difference from the probability in the case of no noise depends on the oracle. In other words, the probability in a case where there is noise changes depending on which state is searched for. Additionally, no matter which state is searched for, generally, as coherent noise increases, the difference between the output probability and the probability in the case of no noise increases. The larger the difference between the output probability and the probability in the case of no noise, the larger the influence of the noise is.
Thus, in the second embodiment, in a case where a quantum circuit includes a plurality of the CCZ gates, the control computer 100 converts a part of the CCZ gates into the equivalent circuit 61, and converts the remaining CCZ gate into an equivalent circuit arranged by symmetrically moving each element of the equivalent circuit 61 up and down.
Next, functions of the control computer 100 will be described in detail.
The quantum calculation control unit 130 controls quantum calculation. First, the quantum calculation control unit 130 acquires a quantum circuit. For example, the quantum calculation control unit 130 receives, from the terminal devices 31, 32, . . . , requests for quantum calculation by the quantum computer 300 and quantum circuits. Then, the quantum calculation control unit 130 controls the qubit control device 200 according to quantum circuits obtained by conversion by the gate conversion unit 150.
The gate detection unit 140 detects a CCZ gate from a quantum circuit acquired by the quantum calculation control unit 130. Furthermore, in a case where the CCZ gate is detected from the quantum circuit, the gate detection unit 140 detects a CCZ gate for the same combination of qubits as the detected CCZ gate.
The gate conversion unit 150 converts gates for equal to or more than three qubits included in a quantum circuit into an equivalent circuit obtained by combining a one-bit gate or a two-bit gate. For example, the gate conversion unit 150 performs conversion into an equivalent circuit obtained by combining a one-bit gate indicating a rotation operation around an axis and the XX gate. For example, the gate conversion unit 150 converts a CCZ gate detected by the gate detection unit 140 into the equivalent circuit 61. Furthermore, the gate conversion unit 150 converts a CCZ gate for the same combination of qubits as the CCZ gate converted into the equivalent circuit into an equivalent circuit obtained by symmetrically moving elements of the converted equivalent circuit. For example, the gate conversion unit 150 converts the CCZ gate into an equivalent circuit arranged by symmetrically moving each element of the equivalent circuit 61 up and down.
Note that, lines coupling the respective elements illustrated in
Next, the conversion information 121 stored in the storage unit 120 will be described in detail.
The gate conversion unit 150 may determine an equivalent circuit corresponding to gate operations of equal to or more than three qubits based on the conversion information 121.
Similarly to the example of
When the quantum circuit 50 is acquired, the quantum calculation control unit 130 controls the qubit control device 200 according to the quantum circuit 50b converted by the gate conversion unit 150. The qubit control device 200 performs gate operations on each qubit in order indicated in the quantum circuit 50b. As a result, a bias of the gate operation on a specific qubit is suppressed as compared with the case where the two CCZ gates included in the quantum circuit 50 are converted into the equivalent circuits 61.
Next, conversion processing of a CCX gate by the gate conversion unit 150 will be described. Note that the CCX gate is also called a Toffoli gate.
In the equivalent circuit 71, the H gate for the qubit q0, the CCZ gate for the qubits q0, q1, and q2, and the H gate for the qubit q0 are arranged side by side. The gate conversion unit 150 may perform conversion into an equivalent circuit for the ion trap quantum computer equivalent to the CCX gate 70 by, for example, converting the CCZ gate included in the equivalent circuit 71 into the equivalent circuit 61.
As described above, the gate conversion unit 150 may convert the CCX gate included in a quantum circuit into an equivalent circuit including the CCZ gate. Additionally, by converting the CCZ gate into an equivalent circuit, the gate conversion unit 150 may suppress a gate operation from being biased to a specific qubit in the quantum circuit including the CCX gate. Additionally, by using the equivalent circuit 71 of the CCX gate 70, it is possible to suppress a bias of the number of operations between qubits even in operations of a large number of bits of equal to or more than four bits.
Next, conversion processing of a CnNOT gate by the gate conversion unit 150 will be described.
An equivalent circuit 73 illustrated in
The equivalent circuit 73 includes two CCX gates in which the qubits q0 and q1 are the control bits and the qubit a0 is the target bit. Furthermore, the equivalent circuit 73 includes two CCX gates in which the qubits q2 and a0 are the control bits and the qubit a1 is the target bit. Furthermore, the equivalent circuit 73 includes two CCX gates in which the qubits q3 and a1 are the control bits and the qubit a2 is the target bit. Furthermore, the equivalent circuit 73 includes two CCX gates in which the qubits q4 and a2 are the control bits and the qubit a3 is the target bit. Furthermore, the equivalent circuit 73 includes one CNOT gate in which the qubit a3 is the control bit and the qubit q5 is the target bit.
The gate conversion unit 150 may convert the CCX gate included in the equivalent circuit 73 into an equivalent circuit obtained by combining the CCZ gate and the H gates (see
The gate conversion unit 150 converts one of the two CCZ gates for the same combination of qubits included in the equivalent circuit 74 into the equivalent circuit 61, and converts the other into the equivalent circuit 66 arranged by symmetrically moving each element of the equivalent circuit 61 up and down. As a result, the gate conversion unit 150 may suppress a gate operation from being biased to a specific qubit in a quantum circuit including the CnNOT gate.
Next, a procedure of the quantum circuit conversion processing will be described in detail.
In this manner, the gate conversion unit 150 converts one of the CCZ gates for the same combination of qubits into an equivalent circuit, and converts the other into an equivalent circuit arranged by symmetrically moving each element of the equivalent circuit 51 up and down. As a result, the gate conversion unit 150 may suppress a gate operation from being biased to a specific qubit.
Note that the gate conversion unit 150 converts the CnNOT gate into the combination of the CCX gates and the CNOT gate, converts the CCX gate into the combination of the CCZ gate and the H gates, and then converts the CCZ gate. As a result, the gate conversion unit 150 may suppress a gate operation from being biased to a specific qubit even in a case where the CCX gate or the CnNOT gate is included in a quantum circuit.
Next, an influence of noise included in a gate operation on quantum calculation will be described.
A graph 82 illustrates a simulation result of quantum calculation by a quantum circuit obtained by converting one of the two CCZ gates included in the Grover's algorithm with the three qubits into the equivalent circuit 61 and converting the other into the equivalent circuit 66 while changing the noise amount of the gate operation. Meanings of a vertical axis, a horizontal axis, and each line of the graph 82 are similar to those of the graph 81.
The graphs 81 and 82 indicate that, when there is no noise of the gate operation, the output probability of the state corresponding to the correct answer data is the theoretical value 0.781 indicated in Expression (7). Furthermore, the graphs 81 and 82 indicate that the output probability of the state corresponding to the correct answer data decreases as the noise amount of the gate operation increases. Here, in the graph 82, a difference between the output probability with respect to the increase in the noise amount and the theoretical value 0.781 is smaller than that in the graph 81. That is, the graphs 81 and 82 indicate that, when quantum calculation is performed by the quantum circuit obtained by converting one of the two CCZ gates into the equivalent circuit 61 and converting the other into the equivalent circuit 66, an influence of noise may be reduced as compared with the case where quantum calculation is performed by the quantum circuit obtained by converting the two CCZ gates into the equivalent circuits 61.
As described above, the gate conversion unit 150 converts one of the CCZ gates for the same combination of qubits into the equivalent circuit 61 and converts the other into the equivalent circuit 66, so that it is possible to reduce an error generated by an influence of noise included in a gate operation being biased to a specific qubit. Therefore, the gate conversion unit 150 may reduce an error in quantum calculation.
Note that the CCZ gate may also be converted into an equivalent circuit other than the equivalent circuits 61 and 66 indicated in the example described above. The gate conversion unit 150 may convert the CCZ gate into an equivalent circuit other than the equivalent circuits 61 and 66.
When a set of equivalent circuits in which one has a configuration obtained by symmetrically moving arrangement of elements of the other is generated among the six equivalent circuits 61 to 66 of the CCZ gate, three sets may be generated. In other words, a set of the equivalent circuit 61 of “#0” and the equivalent circuit 66 of “#5”, a set of the equivalent circuit 62 of “#1” and the equivalent circuit 65 of “#4”, and a set of the equivalent circuit 63 of “#2” and the equivalent circuit 65 of “#4” may be generated. In a case where there are two CCZ gates for the same combination of qubits, the gate conversion unit 150 may convert one CCZ gate into one equivalent circuit constituting any set, and convert the other CCZ gate into the other equivalent circuit constituting the set.
In the graph 84, a difference between the output probability with respect to the increase in the noise amount and the case where there is no noise is smaller than that in the graph 83. Therefore, the graphs 83 and 84 indicate that, when quantum calculation is performed by the quantum circuit obtained by converting one of the two CCZ gates into the equivalent circuit 62 and converting the other into the equivalent circuit 65, an influence of noise may be reduced as compared with the case where quantum calculation is performed by the quantum circuit obtained by converting the two CCZ gates into the equivalent circuits 62.
In the graph 86, a difference between the output probability with respect to the increase in the noise amount and the case where there is no noise is smaller than that in the graph 85. Therefore, the graphs 85 and 86 indicate that, when quantum calculation is performed by the quantum circuit obtained by converting one of the two CCZ gates into the equivalent circuit 63 and converting the other into the equivalent circuit 64, an influence of noise may be reduced as compared with the case where quantum calculation is performed by the quantum circuit obtained by converting the two CCZ gates into the equivalent circuits 63.
A line indicating a result in the case of one type of equivalent circuit in the graph 87 indicates a value obtained by averaging, for each noise amount, the output probabilities of the correct answer data corresponding to the noise amount, which are obtained for the respective correct answer values in a case where quantum calculation is performed using one type of equivalent circuit such as in the graphs 81, 83, and 85. A line indicating a result in the case of two types of equivalent circuits in the graph 87 indicates a value obtained by averaging, for each noise amount, the output probabilities of the correct answer data corresponding to the noise amount, which are obtained for the respective correct answer values in a case where quantum calculation is performed using two types of equivalent circuits constituting a set, such as in the graphs 82, 84, and 86.
As illustrated in the graph 87, in a case where the two CCZ gates are converted into two types of equivalent circuits, a difference between the average probability and the probability in a case where there is no noise is smaller than that in a case where the two CCZ gates are converted into one type of equivalent circuit.
In the graph 88, for the two CCZ gates, the probability obtained in a case where the quantum calculation is executed by the quantum circuit converted into two types of equivalent circuits is a value closer to the probability in the case where there is no noise than a case where the quantum calculation is executed by the quantum circuit converted into one type of equivalent circuit. Therefore, the gate conversion unit 150 may reduce an error in quantum calculation by converting the two CCZ gates into two types of equivalent circuits.
Note that, in the above description, the Grover's algorithm with the three qubits has been described as an example, but the Grover's algorithm may also be executed with equal to or more than four qubits.
The H gate for each of the qubits q0 to q5 is arranged at a left end of the quantum circuit 75. As a first operation indicated by the quantum circuit 75, the H gate is acted on each of the qubits q0 to q5, so that the qubits q0 to q5 are in a superposed state (initialized). Furthermore, in the quantum circuit 75, a combination of the X gate, the H gate, and the CnNOT gate indicating processing of applying the oracle is arranged on the right side of the H gates indicating initialization. Furthermore, in the quantum circuit 75, a combination of the H gates, the X gates, and the CnNOT gate indicating the amplification processing is arranged on the right side of the combination of the gates indicating the oracle. Furthermore, in the quantum circuit 75, observation for each of the qubits q0 to q5 is arranged on the right side of the combination of the gates indicating the amplification processing. By the observation indicated in the quantum circuit 75, a result of performing the inversion amplification processing of the Grover's algorithm once with the six qubits is output.
The gate conversion unit 150 converts the CnNOT gate included in the quantum circuit 75 into a combination of the CCX gates and the CNOT gate, and converts the CCX gate into a combination of the CCZ gate and the H gates. Then, for example, the gate conversion unit 150 converts one of the two CCZ gates for the same combination of qubits converted from the CnNOT gate into the equivalent circuit 61, and converts the other into the equivalent circuit 66.
Next, a difference in probability of correct answer data between a case where the C5NOT gate is converted as in the equivalent circuit 76 and a case where the C5NOT gate is converted as in the equivalent circuit 77 in the quantum circuit that executes the Grover's algorithm with the six qubits will be described.
The graph 91 illustrates a simulation result of quantum calculation by a quantum circuit obtained by converting the two CCZ gates for the same combination of qubits converted from the C5NOT gate as in the equivalent circuit 76 illustrated in
One of lines illustrated in the graph 93 indicates an average of the output probabilities of the state corresponding to the correct answer data in a case where the state corresponding to the correct answer data illustrated in the graph 91 (one type of equivalent circuit) is each of “000000” to “111111”. The other line indicates an average of the output probabilities of the state corresponding to the correct answer data in a case where the state corresponding to the correct answer data illustrated in the graph 92 (two types of equivalent circuits) is each of “000000” to “111111”.
According to the graph 93, a decrease amount of the output probability is smaller in a case where the quantum calculation is executed by the quantum circuit obtained by converting the two CCZ gates into two types of equivalent circuits than in a case where the quantum calculation is executed by the quantum circuit obtained by converting the two CCZ gates into one type of equivalent circuit. That is, the graph 93 indicates that an influence of noise may be reduced more in a case where the quantum calculation is executed by the quantum circuit obtained by converting the two CCZ gates into two types of equivalent circuits than in a case where the quantum calculation is executed by the quantum circuit obtained by converting the two CCZ gates into one type of equivalent circuit.
As described above, even in quantum calculation executed by a quantum circuit including the CnNOT gate, the gate conversion unit 150 may reduce an error generated by an influence of noise included in a gate operation being biased to a specific qubit.
While the embodiments have been exemplified thus far, the configuration of each unit illustrated in the embodiments may be replaced with another configuration having a similar function. Furthermore, other optional components and steps may be added. Moreover, optional two or more configurations (features) of the embodiments described above may be combined.
The above description merely indicates a principle of the present invention. Moreover, numerous modifications and variations may be made by those skilled in the art, and the present invention is not limited to the above-described or illustrated exact configuration and application example, and all corresponding modifications and equivalents are regarded to fall within the scope of the present invention by appended claims and equivalents thereof.
All examples and conditional language provided herein are intended for the pedagogical purposes of aiding the reader in understanding the invention and the concepts contributed by the inventor to further the art, and are not to be construed as limitations to such specifically recited examples and conditions, nor does the organization of such examples in the specification relate to a showing of the superiority and inferiority of the invention. Although one or more embodiments of the present invention have been described in detail, it should be understood that the various changes, substitutions, and alterations could be made hereto without departing from the spirit and scope of the invention.
This application is a continuation application of International Application PCT/JP2021/048573 filed on Dec. 27, 2021 and designated the U.S., the entire contents of which are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2021/048573 | Dec 2021 | WO |
Child | 18664451 | US |