CONTROLLING QUANTUM COMPUTING SYSTEM TO DETERMINE QUANTITY OF OBJECT

Information

  • Patent Application
  • 20240428115
  • Publication Number
    20240428115
  • Date Filed
    June 13, 2024
    7 months ago
  • Date Published
    December 26, 2024
    a month ago
  • CPC
    • G06N10/60
    • G06N10/40
  • International Classifications
    • G06N10/60
    • G06N10/40
Abstract
A system may receive a function ƒ(x) describing a value of an object, values of x, and probabilities p(x) for the values of x. The system may determine a quantum operator U+{right arrow over (ϕ)} that, when executed by a quantum computing system, encodes an approximation of the function ƒ(x) in an amplitude of a quantum state without calculating |ƒ(x) for any of the values of x. The system may instruct the quantum computing system to execute quantum operators (including U+{right arrow over (ϕ)}) to generate a quantum state on a register of qubits, where one of the amplitudes of the generated quantum state includes probabilities p(x) for the values of x and output values of the approximation of the function ƒ(x) for the values of x. The system may determine the value of the object based on the generated quantum state.
Description
BACKGROUND
1. Technical Field

This disclosure relates generally to controlling quantum computing systems, and more particularly, to controlling quantum computing systems to determine quantities of objects.


2. Description of Related Art

Quantum computing systems can be controlled to determine quantities of objects with stochastic behaviors (e.g., pricing of financial derivatives) using Amplitude Estimation (AE). These control methods may provide a quadratic speedup compared to traditional classical Monte Carlo methods. However, the estimated resources required for the quantum circuits of these control methods are considerably higher than what is possible with current and near-term quantum computing devices. Thus, there is a desire to determine new control methods that use fewer quantum resources.





BRIEF DESCRIPTION OF THE DRAWINGS

Embodiments of the disclosure have other advantages and features which will be more readily apparent from the following detailed description and the appended claims, when taken in conjunction with the examples in the accompanying drawings, in which:



FIG. 1 is an example circuit diagram of the quantum operator U+{right arrow over (ϕ)} of Eq. (9).



FIG. 2A is an example plot of the function ƒ(x) of Eq. (30).



FIG. 2B is an example plot of the absolute error between ƒ(x) (from FIG. 2A) and an approximation G(x).



FIG. 3 is a flowchart of an example method for controlling a quantum computing system to determine the value of an object.



FIGS. 4A-4B are block diagrams of an example computing system including a classical computing system and a quantum computing system.



FIG. 4C-4D are block diagrams of example components of a quantum computing system.



FIG. 4E is a flow chart that illustrates an example execution of a quantum routine on the computing system.



FIG. 5 is an example architecture of a classical computing system.





DETAILED DESCRIPTION

The figures and the following description relate to preferred embodiments by way of illustration only. It should be noted that from the following discussion, alternative embodiments of the structures and methods disclosed herein will be readily recognized as viable alternatives that may be employed without departing from the principles of what is claimed.


INTRODUCTION

This disclosure describes controlling quantum computing systems to determine quantities of objects (e.g., quantities that change stochastically). These new techniques use fewer quantum computational resources than conventional techniques. Among other advantages, these new techniques may reduce computational resources by determining quantum operators that enable use of Quantum Signal Processing (QSP) techniques to determine the quantity of an object (e.g., the value of a product). For ease of explanation, the below descriptions describe controlling quantum computing systems in the context of determining pricing for financial derivatives. However, embodiments are not limited to this example use case. For example, the techniques described herein can also be used to control quantum computing systems to determine initial states for differential equations, quantum simulations of field theories and finite element analysis.


In a quantum setting, the quantum circuits which drive the pricing process of a financial derivate may include two components: 1) loading the probability distribution over paths of the stochastic variables involved in the calculation and 2) encoding the payoff of each path into the amplitude of an ancilla qubit. The first component can be represented by an operator custom-character (also “P”) which, given stochastic paths ω∈Ω where each path occurs with probability p(ω), it prepares a probability-weighted superposition of all paths

















𝒫
:





"\[RightBracketingBar]"





0











ω




p

(
ω
)







"\[RightBracketingBar]"




ω



.





(
1
)








The second component is an operator custom-character which computes the discounted payoff ƒ(ω) of the derivative on each path |ωcustom-character, and encodes that value in the amplitude of an ancilla qubit

































:





"\[RightBracketingBar]"




ω






"\[RightBracketingBar]"




0








"\[RightBracketingBar]"




ω






"\[RightBracketingBar]"






f

(
ω
)






(



f

(
ω
)








"\[RightBracketingBar]"




0



+



1
-

f

(
ω
)








"\[RightBracketingBar]"




1



)

.





(
2
)








The operator custom-character=custom-character





































𝒜
:





"\[RightBracketingBar]"







0










"\[RightBracketingBar]"




0





(





ω





p

(
ω
)





f

(
ω
)









"\[RightBracketingBar]"




ω






"\[RightBracketingBar]"






f

(
ω
)







"\[RightBracketingBar]"




0



+






ω





p

(
ω
)





1
-

f

(
ω
)









"\[RightBracketingBar]"




ω






"\[RightBracketingBar]"






f

(
ω
)







"\[RightBracketingBar]"




1



)

,





(
3
)








creates a state such that the probability of measuring |0custom-character in the last qubit is the price of the derivative, represented as the expected value of the discounted payoff, custom-character[ƒ]=Σω∈Ωp(ω)ƒ(ω) (which may be determined by performing amplitude estimation).


However, the implementation of the custom-character operator in Eq. (2) requires binary quantum arithmetic to compute a digital representation of the payoff |ƒ(ω)custom-character from a path |ωcustom-character, before that value is encoded into the amplitude of the last qubit (use of “last,” “final” or “target” to refer to a qubit herein is used for merely for convenience to reference a specific qubit. A “last,” “final” or “target” qubit is not required to be last or final relative to other qubits (e.g., it is not required to be the last or final qubit on a quantum register)). In order to avoid the costly quantum arithmetic of this process, this disclosure shows (among other things) how to determine a quantum operator U+{right arrow over (ϕ)} (alternative to custom-character) using Quantum Signal Processing to generate a quantum state with the value √{square root over (ƒ(ω))} directly in the amplitude of an ancilla qubit, which significantly reduces the total resources used. More specifically, this disclosure enables preparation of the following state:





























"\[RightBracketingBar]"



0








"\[RightBracketingBar]"




0





(





ω





p

(
ω
)





f

(
ω
)









"\[RightBracketingBar]"




ω






"\[RightBracketingBar]"




0



+





ω





p

(
ω
)





1
-

f

(
ω
)









"\[RightBracketingBar]"




ω






"\[RightBracketingBar]"




1



)

.




Overview

Given an n-bit register |xcustom-charactern, and a unitary quantum operator U which creates the state (note that ω from the previous descriptions is replaced with x)







































U




"\[RightBracketingBar]"




x



n




"\[RightBracketingBar]"




0




n
+
1


=




"\[RightBracketingBar]"




x



n



(


x







"\[RightBracketingBar]"





ψ
0




n




"\[RightBracketingBar]"




0



+



1
-
x







"\[RightBracketingBar]"





ψ
1




n




"\[RightBracketingBar]"




1



)

,





(
4
)








where |ψ0custom-charactern and |ψ1custom-charactern are normalized quantum states, the goal is to generate a unitary quantum operator U+{right arrow over (ϕ)} that prepares the state













































"\[RightBracketingBar]"




x



n




"\[RightBracketingBar]"




0




n
+
a







"\[RightBracketingBar]"




x



n



(





A


e
x


-
B

c








"\[RightBracketingBar]"





ψ
0
l




n




"\[RightBracketingBar]"




0



a

+


1
-



A


e
x


-
B

C







"\[RightBracketingBar]"





ψ
1





n




"\[RightBracketingBar]"





0





a

)

,





(
5
)








for normalized quantum states |ψ0custom-charactern, |ψ1custom-charactern, and |0custom-charactera denoting a normalized state orthogonal to |0custom-charactera. A, B, C are constants such that (Aex−B)/C∈[0,1]. To prepare the unitary quantum operator of Eqn. (5), aspects from Quantum Signal Processing may be used as further described below. Quantum Signal Processing is also generally described below in the section titled “Quantum Signal Processing.”


Defining projectors {tilde over (Π)}≡custom-character⊗2n⊗|0custom-charactercustom-character0| and Π≡custom-character⊗n⊗(0custom-charactercustom-character0|)⊗n+1, observe that {tilde over (Π)}UΠ is a rank-1 matrix with a single non-trivial singular value √{square root over (x)}. Consecutive invocations of U and U, interleaved with projector-controlled rotation operators Πϕ=custom-character and {tilde over (Π)}ϕ=custom-character, enables applications of polynomial transformations to this singular value, using the Quantum Signal Processing framework. Given phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd), define










U

ϕ



=

{








~


ϕ
1



U







k
=
1





(

d
-
1

)

/
2








ϕ

2

k





U







~


ϕ


2

k

+
1



U





,





for


odd


d

,













k
=
1


d
/
2







ϕ


2

k

-
1





U







~


ϕ

2

k



U




,




for


even


d










(
6
)



























U
C

ϕ



=

(


U

ϕ











"\[RightBracketingBar]"




0









0





"\[RightBracketingBar]"



+


U

-

ϕ











"\[RightBracketingBar]"




1









1





"\[RightBracketingBar]"



)

.





(


7


)








Then, for any polynomial G satisfying deg(G)≤d, |G(a)|≤1, ∀a∈[−1,1], and G either even or odd, there exist phase factors {right arrow over (ϕ)} such that the unitary











U
+

ϕ



=


(






2

n


+
1



H

)




U
C

ϕ



(






2

n


+
1



H

)



,




(
8
)







creates the state


























U
+

ϕ






"\[RightBracketingBar]"




x



n




"\[RightBracketingBar]"




0




n
+
1





"\[RightBracketingBar]"




0



=




"\[RightBracketingBar]"




x



n



{

















(


G

(

x

)

|

ψ
0






n




"\[RightBracketingBar]"




0



2

+

















1
-


G

(

x

)

2




|

ψ
0





n




"\[RightBracketingBar]"






0






2

)

,








for


odd


d

,




















(

G

(

x

)





"\[RightBracketingBar]"




0




n
+
2


+












1
-


G

(

x

)

2



|


0







n
+
2


)

,








for


even


d

,













(
9
)








With an appropriately chosen polynomial G which approximately performs








G



(

x

)








A


e
x


-
B

C




,




the unitary U+{right arrow over (ϕ)} can be used to approximately prepare the target state in Eq. (5). A circuit description of the operator U+{right arrow over (ϕ)} is shown in FIG. 1. After identifying a polynomial G to be applied with Quantum Signal Processing, the corresponding phase factors {right arrow over (ϕ)} for U+{right arrow over (ϕ)} can be calculated1. 1The corresponding phase factors may be calculated using the teachings of: Y. Dong, X. Meng, K. B. Whaley, and L. Lin. “Efficient phase-factor evaluation in quantum signal processing.” Physical Review A 103, 042419 (2021). Link: https://journals.aps.org/pra/abstract/10.1103/PhysRevA.103.042419



FIG. 1 is a circuit diagram of the U+{right arrow over (ϕ)} operator of Eq. (9) based on the unitary U of Eq. (4). The choice of angles {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) determines the exact d-degree polynomial G applied to the state, such that the probability of measuring |00custom-character in the bottom two qubits if d is odd and |0custom-character in the bottom n+2 qubits if d is even, will be given by |G(√{square root over (x)})|2.


Implementation

This section shows how to implement the unitary U of Eq. (4) and the choice of polynomial G used in Eq. (9) in order to construct the target state Eq. (5). This section assumes that the register |xcustom-character is an n-bit, binary, fixed-point representation of a scalar x with p digits to the left of the binary point









x
=





x

n
-
1








x

n
-
p





p

·





x

n
-
p
-
1








x
0





n
-
p


.







(
10
)








First consider the case where x is positive with p=0, such that x<1










x
=







i
=
0


N
-
1






x
i

·

2
i


N



,





(
11
)








where xi∈0, 1 denotes the i-th bit of |xcustom-character and N=2n. The first step to implement the transformation of Eq. (5) is to encode the value √{square root over (x)} to the amplitude of an ancilla qubit. Start with the state |xcustom-character and apply Hadamard gates to n ancilla qubits to generate a uniform superposition:




























"\[RightBracketingBar]"


x



n




"\[RightBracketingBar]"



+



n

=







j
=
0


N
-
1




1

N







"\[RightBracketingBar]"




x



n




"\[RightBracketingBar]"




j



n

.





(
12
)








Then apply the following unitary operator






















𝒞
:

|
a



|
b



|
0





|
a



|
b



|

a
<
b








(
13
)








to perform a binary comparison2 between the two qubit registers of Eq. (12), which produces the state 2An example for implementing the comparator operator custom-character can be found at: T. G. Draper, S. A. Kutin, E. M. Rains, and K. M. Svore, “A logarithmic-depth quantum carry-lookahead adder,” Quantum Information and Computation 6, 351 (2006). Link: https://arxiv.org/abs/quant-ph/0406142


















































j
=
0


N
-
1




1

N






"\[RightBracketingBar]"




x



n




"\[RightBracketingBar]"




j



n




"\[RightBracketingBar]"






N

·
x


<
j



=







"\[RightBracketingBar]"




x



n




[







j
=
0



N
·
x

-
1




1

N








"\[RightBracketingBar]"




j



n




"\[RightBracketingBar]"




0



+







j
=

N
·
x



N
-
1




1

N







"\[RightBracketingBar]"




j



n




"\[RightBracketingBar]"




1



]

,




(
14
)







with x given by Eq. (11). The probability of measuring |0custom-character in the comparator ancilla qubit is then








N
·
x

N

=

x
.





The unitary U=custom-character(custom-character⊗H⊗ncustom-character) acting on the state |xcustom-character|0custom-character therefore creates the target state of Eq. (4)


































U
|
x



n

|
0




n
+
1


=




"\[RightBracketingBar]"




x



n



(


x

|

ψ
0






n




"\[RightBracketingBar]"




0



+


1
-
x



|

ψ
1




n




"\[RightBracketingBar]"




1



)

,





(
15
)








where |ψ0custom-character and |ψ1custom-character n are normalized quantum states which depend on the value of x. A polynomial G which approximates the function











f

(
x
)







A


e

x
2



-
B

C




,





(
16
)








in the domain x∈[0,1] allows approximate preparation of the target state given by Eq. (5) using Eq. (9).


When p>0 such that x≥1 (see Eqn. (10)), the unitary U as above may be used, ignoring the location of the binary point p, which in this case generates the state


































U
|
x



n

|
0




n
+
1


=




"\[RightBracketingBar]"




x



n



(




x

2
p




|

ψ
0






n




"\[RightBracketingBar]"




0



+



1
-

x

2
p






|

ψ
1




n




"\[RightBracketingBar]"




1



)

.




(
17
)







Because of the extra factor of 2p, the polynomial G in this case approximates the function











f

(
x
)







A


e


x
2

·

2
p




-
B

C




,





(
18
)








in order to generate the target state of Eq. (5).


In order to handle negative values of x, first pick a value s≥|x|≥0 and then apply a binary addition circuit which performs |xcustom-character|0custom-character→|xcustom-character|x+scustom-character, where |x+scustom-character is again a fixed-point register with m total digits and p to the left of the binary point (thus increasing the x values to all be zero or positive). The unitary U of Eq. (17) is then applied with the second register as input to construct the state





























U




"\[LeftBracketingBar]"


x
+
s





m





"\[LeftBracketingBar]"

0





m
+
1


=



"\[LeftBracketingBar]"


x
+
s





m



(





x
+
s


2
p








"\[LeftBracketingBar]"


ψ
0







m





"\[LeftBracketingBar]"

0







+



1
-


x
+
s


2
p








"\[LeftBracketingBar]"


ψ
1






m





"\[LeftBracketingBar]"

1




)

,




(
19
)







where the normalization factor 2p arising from treating the fixed-point register |x+scustom-character as a binary string in the comparator circuit, similarly handles the case x≤−1.0. The polynomial G which generates the target state of Eq. (5) approximates the function












f

(
x
)



"\[Rule]"







Ae







x





2



·

2





p






e






-
s




-
B

C


.





(
20
)








Note that for both positive and negative values of x, the transformation in Eq. (19) guarantees that the input to the polynomial G will only be the domain x∈[0,1]. This way, while only polynomials with definite parity (either even or odd) can be implemented using Quantum Signal Processing, the function being approximated with Quantum Signal Processing can be extended to the domain x∈[−1,1] using ƒ(−x)=ƒ(x) or ƒ(−x)=−ƒ(x), even if ƒ(x) does not have definite parity. Additionally, the unitary U of Eq. (19) and the function Eq. (20) allow construction of the target state for any input x, provided that ƒ(x)∈[0, 1].


Application

This section describes how the descriptions in the previous sections to prepare the state in Eq. (5) can be used in derivative pricing to compute example payoffs of the form ƒ(S)=max(0, S−K), by considering a European call option. Given a strike price K, the holder of a European call option contract receives at a future date T (the expiration date) the amount













f

(

S
T

)

=

max

(

0
,


S
T

-
K


)


,




(
21
)








where ST is the market price of an underlying asset (which is an example of an object) at date T. In order to determine the value of this contract today, the future price of the underlying asset is modeled as a stochastic variable with an appropriate probability distribution, and the price of the option is calculated by computing the expectation value of its payoff in Eq. (21).


An example re-parameterization method for derivative pricing3 implements the operator of Eq. (1) by loading a discretized normal distribution and then performing an affine transformation to the registers using quantum arithmetic to generate a superposition of possible log-returns ri at time T, each weighed by the probability of occurrence 3For more details, see: S. Chakrabarti, R. Krishnakumar, G. Mazzola, N. Stamatopoulos, S. Woerner, and W. J. Zeng. “A Threshold for Quantum Advantage in Derivative Pricing,” Quantum 5, 463 (2021). Link: https://quantum-journal.org/papers/q-2021-06-01-463/




















i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i





n

,




(
22
)








where N=2n. In this example, the price of the underlying asset for each possible log-return ri is then given by Si=S0eri, where S0 is the price of the underlying asset today. The payoff operator of Eq. (2) is implemented by first calculating the price of the underlying asset from the log-return into another register






















i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i





n



"\[Rule]"











i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i





n






"\[LeftBracketingBar]"




S
i

=


S
0



e






r
i










,




(
23
)








computing the payoff of Eq. (21)





























i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i





n






"\[LeftBracketingBar]"



S
i







"\[Rule]"








i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i






n






"\[LeftBracketingBar]"



S
i










"\[LeftBracketingBar]"




f

(


S


i



)





,




(
24
)








and finally encoding the payoff into the amplitude of an ancilla qubit




































i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i





n






"\[LeftBracketingBar]"



S
i










"\[LeftBracketingBar]"




f

(


S


i



)







"\[Rule]"








i
=
0


N
-
1





p
i






"\[LeftBracketingBar]"


r
i






n






"\[LeftBracketingBar]"



S
i










"\[LeftBracketingBar]"




f

(


S


i



)










(





max

(

0
,


S
i

-
K


)


f
max








"\[LeftBracketingBar]"

0






+




1
-

max

(

0
,


S
i

-
K


)



f
max







"\[LeftBracketingBar]"

1





)

,




(
25
)








where ƒmax=emax{ri}−K is the maximum value of the payoff possible by the discretization chosen in Eq. (22). The probability of measuring |0custom-character in the last qubit is

















[



"\[LeftBracketingBar]"

0




]

=







i
=
0


N
-
1




p
i




max

(

0
,


S
i

-
K


)


f
max




,




(
26
)








which is the expectation value of the option's payoff, normalized by ƒmax. Thus, applying amplitude estimation to the last qubit estimates the price of the option.


However, the above example re-parameterization method requires explicit computation of the values |Si=S0ericustom-character and |ƒ(Si)custom-character using quantum arithmetic (e.g., computing these values digitally using qubits like classical bits and performing the same arithmetic logic as in a classical computing system), which is resource intensive. In contrast, the following paragraphs describe using the techniques described in previous sections to determine the price of the option without using quantum arithmetic to explicitly calculate these values.


Let the |ricustom-character register of Eq. (22) represent each log-return in fixed-point representation and let s=ln(S0/K). Apply a circuit which performs the comparison |riρ|0custom-character→|ricustom-character|ri≤scustom-character to Eq. (22) to get
























{

i




"\[LeftBracketingBar]"



r
i

>
s



}





p
i






"\[LeftBracketingBar]"


r
i





n






"\[LeftBracketingBar]"


0




+










{

i




"\[LeftBracketingBar]"



r
i







s




}





p
i






"\[LeftBracketingBar]"


r
i





n






"\[LeftBracketingBar]"


1





.




(
27
)








Add an m-qubit register and compute |riρ|0custom-character→|ricustom-character|ri+|s|custom-character, where the second register is also a fixed-point representation and m is large enough to hold the maximum value of ri+|s|, to get


























{

i




"\[LeftBracketingBar]"



r
i

>
s



}





p
i






"\[LeftBracketingBar]"


r
i





n





"\[LeftBracketingBar]"



r
i

+



"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"







m





"\[LeftBracketingBar]"

0




+



,




(
28
)








where terms with the last qubit being in the |1custom-character state are ignored. Note that 0≤ri+|s|<2p if the register |ri+|s|custom-character has p digits to the left of the binary point. The application of the U operator of Eq. (19) to the |ri+|s|custom-character register and a new qubit register |0custom-character gives




































{

i




"\[LeftBracketingBar]"



r
i

>
s



}





p
i






"\[LeftBracketingBar]"


r
i





n





"\[LeftBracketingBar]"



r
i

+




"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"







m



(





r
i

+



"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"




2





p








"\[LeftBracketingBar]"


ψ
0







m





"\[LeftBracketingBar]"

0




+



1
-



r
i

+



"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"




2





p









"\[LeftBracketingBar]"


ψ
1






m





"\[LeftBracketingBar]"

1




)





"\[LeftBracketingBar]"

0




,




(
29
)








for normalized quantum states |ψ0custom-character and |ψ1custom-character. Employing the Quantum Signal Processing unitary U+{right arrow over (ϕ)} of Eq. (9) with phases {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) chosen such that the polynomial G approximates the function












f

(
x
)

=





S
0



e







x





2



·

2





p






e






-



"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"






-
K


f
max







(
30
)








produces





























{

i




"\[LeftBracketingBar]"



r
i

>
s



}





p
i






"\[LeftBracketingBar]"


r
i





n





"\[LeftBracketingBar]"



r
i

+



"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"







m



(






S
0



e






r
i




-
K


f
max








"\[LeftBracketingBar]"



ψ
0














m





"\[LeftBracketingBar]"

B




)

,




(
31
)








with |Bcustom-character=|0custom-character for odd d, and


























{

i




"\[LeftBracketingBar]"



r
i

>
s



}





p
i






"\[LeftBracketingBar]"


r
i





n





"\[LeftBracketingBar]"



r
i

+



"\[LeftBracketingBar]"

s


"\[RightBracketingBar]"







m



(






S
0



e






r
i




-
K


f
max







"\[LeftBracketingBar]"

B






)

,




(
32
)








with |Bcustom-character=|0custom-character for even d, where terms with any qubit in the last register being in the |1custom-character state are ignored. Applying amplitude estimation to estimate the probability of measuring the |Bcustom-character state gives

















[



"\[LeftBracketingBar]"

B




]

=







{

i




"\[LeftBracketingBar]"



r
i

>
s



}




p
i






S
0



e






r
i




-
K


f
max




,




(
33
)








which is the same as the value estimated using the example re-parameterization method in Eq. (26). However, among other advantages, the method of equations 27-33 does not use quantum arithmetic to explicitly compute the values of |Si=S0ericustom-character and |ƒ(Si)custom-character, but instead these values are implicitly calculated by amplitude transformations using Quantum Signal Processing.



FIG. 2A is a plot of the function ƒ(x) of Eq. (30) used to compute the payoff of a European call option and d=16-degree approximating Chebyshev polynomial G(x), which can be applied to a quantum system using the Quantum Signal Processing unitary of Eq. (9). FIG. 2B is a plot of the absolute error between ƒ(x) and the approximation G(x). For both plots the following values were used: S0=K=100 and p=3, giving ƒmax=S0e2p−K.


Example Methods

Although previous descriptions provide examples methods for controlling a quantum computing system to determine the value of an object (e.g., determining the price of a financial derivative), the below paragraphs describe additional examples. The descriptions below may omit steps previously described and/or include steps that are in addition to or alternative to the steps previously described.



FIG. 3 is a flowchart of an example method 300 for controlling a quantum computing system to determine the value of an object (e.g., determining the price of a financial derivative). Note that the below description makes several references to FIG. 4, which is further described below. In the example of FIG. 3, the method 300 is performed from the perspective of a (e.g., classical) computing system (e.g., 410) that can instruct and/or control a quantum computing system (e.g., 420). The method 300 can include greater or fewer steps than described herein. Additionally, the steps can be performed in different order or by different components than described herein. In some embodiments, the method 300 is performed by the computing system executing code stored on a (e.g., non-transitory) computer-readable storage medium that causes the computing system to perform the steps of method 300.


At step 310, the computing system receives a function ƒ(x) describing a value of an object (which is an example of a quantity of the object), values of x, and probabilities p(x) for the values of x.


At step 320, the computing system receives (or determines) a quantum operator P (also “custom-character”) that, when executed by a first quantum computing system (e.g., 420), creates a first quantum state characterized by a superposition of states encoding the x values, where the amplitude for a corresponding x value is the square root of the probability p(x) for that x value. The first quantum state may be a probability weighted superposition for all the values of x. For example, the first quantum state is given by Σx√{square root over (p(x))}|xcustom-character, where |xcustom-character is a quantum state on an n-qubit register storing an n-bit binary representation of the corresponding value of x. For additional information on the quantum operator P, see e.g., Eqns. (1) and (22) and associated descriptions (note that in Eqn. (1), the symbol ω is used instead of x).


At step 330, the computing system determines a quantum operator U+{right arrow over (ϕ)} (e.g., see Eqn. (9) and associated description) that, when executed by a quantum computing system (e.g., 420 or another quantum computing system), encodes an approximation of the function ƒ(x) in an amplitude of a second quantum state without calculating |ƒ(x)custom-character for any of the values of x(|ƒ(x)custom-character is a binary representation of an output value of ƒ(x) stored on qubits of a quantum register). Note that U+{right arrow over (ϕ)} in FIG. 3 is represented by the following symbol: Uphi+. The approximation of the function ƒ(x) is within an error threshold of the function ƒ(x). In general, to decrease the approximation error, the computational resources are increased. Thus, the error of the approximation may be based on the available resources and the error target threshold of the value for the object being determined.


Steps 310, 320, and 330 may be part of example step 460 in FIG. 4E.


At step 340, the computing system controls (e.g., instructs) a third quantum computing system (e.g., 420 or another quantum computing system) to execute both of the quantum operators P and U+{right arrow over (ϕ)} to generate a third quantum state on a register of qubits. One of the amplitudes of the third quantum state includes probabilities p(x) for the values of x and output values of the function ƒ(x) for the values of x. Instructing the third quantum computing system to execute both of the quantum operators P and U+{right arrow over (ϕ)} includes instructing the third quantum computing system to execute the quantum operator P prior to executing the quantum operator U+{right arrow over (ϕ)}.


In some aspects, the one of the amplitudes of the third quantum state is the square root of the weighted average of ƒ(x) for the x values where the weights are the probabilities p(x) for the corresponding values of x. Said differently, the one of the amplitudes is Σx√{square root over (p(x))}√{square root over (ƒ(x))} (which means the probability of measuring the state associated with the one of the amplitudes is custom-character[ƒ]=Σxp(x)ƒ(x)).


Step 340 may be part of example step 465 in FIG. 4E.


At step 350, the computing system determines the value of the object based on the generated third quantum state.


Step 350 may be part of example step 475 in FIG. 4E.


In some aspects, the method 300 does not include calculating |ƒ(x)custom-character.


In some aspects, the method 300 further includes determining s, where s is based on the absolute values of the x values; and instructing the third quantum computing system to apply a quantum binary addition circuit that performs the operation: |xcustom-character|0custom-character→|xcustom-character|x+scustom-character, where n and m are integers greater than zero, m>n, |xcustom-character is a quantum state on an n-qubit register storing an n-bit binary representation of a value of x, and |x+scustom-character is a quantum state on an m-qubit register storing a representation of a value of x+s with m total digits and p digits to the left of the binary point. In some aspects, s is based on the upper bound of the absolute values of the x values (e.g., s≥|x|≥0). For example, s is the absolute value of the smallest x value of the values of x (however, s may be larger than this). For example, if the x values range from 4 to −5, then s=5.


In some aspects, the quantum binary addition circuit is executed subsequent to execution of the quantum operator P but prior to execution of the quantum operator U+{right arrow over (ϕ)}.


For additional information on s and the quantum binary addition circuit, see e.g., Eqns. (18)-(19) and (27)-(29) and their associated descriptions.


In some aspects, determining the quantum operator U+{right arrow over (ϕ)}, includes generating an if initial quantum operator given by U=C(custom-character⊗H⊗mcustom-character), where C is a comparator quantum circuit defined by C:|acustom-character|bcustom-character|0custom-character→|acustom-character|bcustom-character|a<bcustom-character, I is an identity matrix, and H is a Hadamard gate. For more information on the initial quantum operator U, see Eqns. (10)-(15) and their associated descriptions.


In some aspects, determining the quantum operator U+{right arrow over (ϕ)} further includes applying the initial quantum operator U to state |x+scustom-character|0custom-character to generate the following quantum state:



























U




"\[LeftBracketingBar]"


x
+
s





m





"\[LeftBracketingBar]"

0





m
+
1


=



"\[LeftBracketingBar]"


x
+
s





m



(




x
+
s


2





p








"\[LeftBracketingBar]"


ψ
0







m





"\[LeftBracketingBar]"

0




+



1
-


x
+
s


2





p









"\[LeftBracketingBar]"


ψ
1






m





"\[LeftBracketingBar]"

1




)

,
where














"\[LeftBracketingBar]"


ψ
0




m






and








"\[LeftBracketingBar]"


ψ
1





m




are normalized quantum states. For more information, see Eqn. (4)-(5) and (15)-(19) and their associated descriptions.


In some aspects, determining the quantum operator U+{right arrow over (ϕ)} includes performing a Quantum Signal Processing (QSP) algorithm. Performing the QSP algorithm may include determining phase parameters representing a polynomial approximation that approximates











A


e

(


x
2

·

2
p


)




e

-
s



-
B

C



,




where A, B, and C are constants: (1) based on the function ƒ(x) and (2) that satisfy









A


e

(


x
2

·

2
p


)




e

-
s



-
B

C




[

0
,
1

]

.





For more information, see Eqns. (20) and (3) and their associated descriptions. The approximation error of the polynomial approximation may be within a target error threshold of the target function (which in this case is













A


e

(


x
2

·

2
p


)




e

-
s



-
B


C






)



.





In general, to decrease the approximation error, the degree of the polynomial is increased, which increases the computational resources to perform the calculation. Thus, the error of the polynomial approximation may be based on the available resources and the error target threshold for the value of the object being determined.


In some aspects, the function ƒ(x) is a normalized function with output values ranging from zero to one.


In some aspects, the value (an example of a quantity of the object) of the object fluctuates stochastically.


In some aspects, determining the value of the object based on the generated quantum state includes performing an amplitude estimation algorithm to determine value of the object.


Some aspects relate to new example method including: instructing (e.g., by a classical computing system 410) a quantum computing system (e.g., 420) to execute a quantum operator that prepares an approximation to a target quantum state given by:




































|
x



n




"\[RightBracketingBar]"




0




n
+
a




|
x



n



(





A


e
x


-
B

C








"\[RightBracketingBar]"





ψ
0





n





"\[RightBracketingBar]"




0



a

+



1
-



A


e
x


-
B

C








"\[RightBracketingBar]"





ψ
1





n





"\[RightBracketingBar]"





0





a

)

,




where x is a scalar number; |xcustom-character is a quantum state on an n-qubit register of the quantum computing system storing an n-bit binary representation of x; n and a are integers greater than zero; |ψ0custom-character and |ψ0custom-character are normalized quantum states; |0custom-character is a normalized quantum state orthogonal to |0custom-character; A, B, and C are constants such that (Aex−B)/C∈[0, 1]; and the approximation is within an error threshold of










A


e
x


-
B

C


.




In some aspects, the quantum computing system executes the quantum operator on a register of qubits.


Other aspects include components, devices, systems, improvements, methods, processes, applications, computer readable mediums, and other technologies related to any of the above.


Quantum Signal Processing

This section provides a general description of Quantum Signal Processing (QSP). QSP is a technique which performs polynomial transformations to the singular values of a matrix A that has been block-encoded into a unitary operator. Specifically, given projectors Π and {tilde over (Π)}, a unitary U acting on n qubits is a block-encoding of a matrix A if A={tilde over (┌)}UΠ, such that the projectors Π and {tilde over (Π)} determine the location of A in U









U
=








Π






Π
~





[



A


·




·


·



]

.

















(
34
)








QSP includes consecutive applications of U and U, interleaved with projector-controlled rotation operators Πϕ=custom-character and {tilde over (Π)}ϕ=custom-character, which for phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) induce a polynomial transformation on A such that













A
=






k



σ
k


|


w
k















v
k

|



G

(
A
)



=






k



G

(

σ
k

)


|


w
k













v
k






"\[RightBracketingBar]"



,





(
35
)








where σk denote the singular values of A while {|wkcustom-character}, {|vkcustom-character} are the left and right singular vectors of A respectively, and G is a d-degree polynomial. When A is Hermitian, in which case the singular values of the matrix coincide with its eigenvalues, Quantum Signal Processing effectively performs a polynomial transformation to the eigenvalues of the matrix.


More formally, define the operators










u

ϕ



=

{








~


ϕ
1



U







k
=
1



(

d
-
1

)

/
2







ϕ

2

k





U







~


ϕ


2

k

+
1



U





,


for


odd


d

,












k
=
1





d
/
2







ϕ


2

k

-
1





U







~


ϕ

2

k



U




,


for


even


d










(
36
)

















u
C

ϕ



=

(


u

ϕ







"\[LeftBracketingBar]"


0














0





"\[LeftBracketingBar]"




+

u

-

ϕ









"\[LeftBracketingBar]"


1














1



"\[LeftBracketingBar]"





)

.





(
37
)








If U is an n-qubit unitary, the polynomial transformation achieved through QSP is implemented with










U

ϕ



=



(







n





H

)



u
C

ϕ
_




(







n





H

)



=








Π






Π





[




G

(
A
)



·




·


·



]


















(
38
)








where Π′={tilde over (Π)} for odd d and {tilde over (Π)}′=Π for even d.


In practice, d invocations of U perform a d-degree polynomial transformation to A and the choice of phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) determine the exact polynomial that is applied. Remarkably, the reverse is also true: for a∈[−1, 1] and any real polynomial G∈custom-character(a), there exists a sequence of QSP phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) for which Eqn. (38) holds, as long as deg(G)≤d, |P(a)|≤1, ∀a∈[−1, 1], and G either even or odd. Additionally, for any function ƒ(a) satisfying these conditions a polynomial approximation to the function can be identified, the QSP phase factors {right arrow over (ϕ)} for that polynomial can be determined, and QSP used to approximately apply ƒ(a) to the singular values of the block-encoded matrix. Various methods have been proposed to generate polynomial approximations to generic functions, where the approximation is either constructed analytically or with optimization-based numerical methods.


Description of a Computing System

Embodiments described above may be implemented using one or more computing systems. Example computing systems are described below.



FIG. 4A is a block diagram that illustrates an embodiment of a computing system 400. In the example of FIG. 4A, the computing system 400 includes a classical computing system 410 (also referred to as a non-quantum computing system) and a quantum computing system 420, however a computing system may just include a classical computing system or a quantum computing system. An embodiment of the classical computing system 410 is described further with respect to FIG. 5. While the classical computing system 410 and quantum computing system 420 are illustrated together, they may be physically separate systems. For example, FIG. 4B illustrates an example cloud computing architecture where the computing system 410 and the quantum computing system 420 communicate via a network 457. The computing system 400 may include different or additional elements than illustrated (e.g., multiple quantum computing systems 420).


The classical computing system 410 may control the quantum computing system 420. For example, the classical computing system 410 generates and transmits instructions for the quantum computing system 420 to execute a quantum algorithm or quantum circuit. Although only one classical computing system 410 is illustrated in FIG. 4A, any number of classical computing system 410 or other external systems may be connected to the quantum computing system 420.



FIG. 4C is a block diagram that illustrates an embodiment of the quantum computing system 420. The quantum computing system 420 includes any number of quantum bits (“qubits”) 450 and associated qubit controllers 440. As illustrated in FIG. 4D, the qubits 450 may be in a qubit register of the quantum computing system 420 (or multiple registers). Qubits are further described below. A qubit controller 440 is a module that controls one or more qubits 450. A qubit controller 440 may include one or more classical processors such as one or more CPUs, one or more GPUs, one or more FPGAs, or some combination thereof. A qubit controller 440 may perform physical operations on one or more qubits 450 (e.g., it can perform quantum gate operations on a qubit 440). In the example of FIG. 4C, a separate qubit controller 440 is illustrated for each qubit 450, however a qubit controller 450 may control multiple (e.g., all) qubits 450 of the quantum computing system 420 or multiple controllers 450 may control a single qubit. For example, the qubit controllers 450 can be separate processors, parallel threads on the same processor, or some combination of both.



FIG. 4E is a flow chart that illustrates an example execution of a quantum routine on the computing system 400. The classical computing system 410 generates 460 a quantum program to be executed or processed by the quantum computing system 420. The quantum program may include instructions or subroutines to be performed by the quantum computing system 420. In an example, the quantum program is a quantum circuit. The quantum computing system 420 executes 465 the program and computes 470 a result (referred to as a shot or run). Computing the result may include performing a measurement of a quantum state generated by the quantum computing system 420 that resulted from executing the program. Practically, this may be performed by measuring values of one or more of the qubits 450. The quantum computing system 420 typically performs multiple shots to accumulate statistics from probabilistic execution. The number of shots and any changes that occur between shots (e.g., parameter changes) may be referred to as a schedule. The schedule may be specified by the program. The result (e.g., quantum state data) (or accumulated results) is recorded 475 by the classical computing system 410. Results may be returned after a termination condition is met (e.g., a threshold number of shots occur). The classical computing system 410 may determine a quantity based on the received results.


The quantum computing system 420 exploits the laws of quantum mechanics in order to perform computations. A quantum processing device (QPU), a quantum computer, a quantum processor system, and a quantum processing unit are each examples of a quantum computing system. The quantum computing system 420 can be a universal or a non-universal quantum computing system (a universal quantum computing system can execute any possible quantum circuit (subject to the constraint that the circuit doesn't use more qubits than the quantum computing system)). In some embodiments, the quantum computing system 420 is a gate model quantum computer. As previously described, quantum computing systems use so-called qubits, or quantum bits (e.g., 450A). While a classical bit always has a value of either 0 or 1, a qubit is a quantum mechanical system that can have a value of 0, 1, or a superposition of both values. Example physical implementations of qubits include superconducting qubits, spin qubits, trapped ions, arrays of neutral atoms, and photonic systems (e.g., photons in waveguides). For the purposes of this disclosure, a qubit may be realized by a single physical qubit or as an error-protected logical qubit that itself comprises multiple physical qubits. Additionally, the disclosure is not specific to qubits. The disclosure may be generalized to apply to quantum computing systems 420 whose building blocks are qudits (d-level quantum systems, where d>2) or quantum continuous variables, rather than qubits.


A quantum operator (e.g., U+{right arrow over (ϕ)} or P) may be one or more quantum circuits. A quantum circuit is an ordered collection of one or more gates. A sub-circuit may refer to a circuit that is a part of a larger circuit. A gate represents a physical unitary operation performed on one or more qubits (e.g., changing the state of a qubit from 0 to 1 or creating a superposition of 0 and 1). Quantum gates may be described using unitary matrices. The depth of a quantum circuit is the least number of steps used to execute the circuit on a quantum computing system (e.g., 420). The depth of a quantum circuit may be smaller than the total number of gates because gates acting on non-overlapping subsets of qubits may be executed in parallel. A layer of a quantum circuit may refer to a step of the circuit, during which multiple gates may be executed in parallel. In some embodiments, a quantum circuit is executed by a quantum computing system. In this sense, a quantum circuit can be thought of as comprising a set of instructions or operations that a quantum computing system can execute. To execute a quantum circuit on a quantum computing system, a user may inform the quantum computing system what circuit is to be executed. A quantum computing system may include both a core quantum device and a classical peripheral/control device (e.g., a qubit controller 440) that is used to orchestrate the control of the quantum device. It is to this classical control device that the description of a quantum circuit may be sent when one seeks to have a quantum computer execute a circuit.


The parameters of a parameterized quantum circuit may refer to parameters of the gates. For example, a gate that performs a rotation about the y axis may be parameterized by a real number that describes the angle of the rotation.


The description of a quantum circuit to be executed on one or more quantum computing systems may be stored in a non-transitory computer-readable storage medium. The term “computer-readable storage medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store instructions. The term “computer-readable medium” shall also be taken to include any medium that is capable of storing instructions for execution by the quantum computing system and that cause the quantum computing system to perform any one or more of the methodologies disclosed herein. The term “computer-readable medium” includes, but is not limited to, data repositories in the form of solid-state memories, optical media, and magnetic media.



FIG. 5 is an example architecture of an example classical computing system 500 (e.g., 410). The quantum computing system 420 may also have one or more components described with respect to FIG. 5. FIG. 5 depicts a high-level block diagram illustrating physical components of a classical computing system used as part or all of one or more entities described herein, in accordance with an embodiment. A classical computing system may have additional, less, or variations of the components provided in FIG. 5. Although FIG. 5 depicts a classical computing system 500, the figure is intended as functional description of the various features which may be present in computing systems than as a structural schematic of the implementations described herein. In practice, and as recognized by those of ordinary skill in the art, items shown separately could be combined and some items could be separated.


Illustrated in FIG. 5 are a processor 502 coupled to a chipset 504. Also coupled to the chipset 504 are a memory 506, a storage device 508, a keyboard 510, a graphics adapter 512, a pointing device 514, and a network adapter 516. Although only a single processor 502 is illustrated in FIG. 5, the classical computing system 500 may include multiple processors capable of working individually or collectively to perform a process (e.g., one or more steps of method 300). A display 518 is coupled to the graphics adapter 512. In one embodiment, the functionality of the chipset 504 is provided by a memory controller hub 520 and an I/O hub 522. In another embodiment, the memory 506 is coupled directly to the processor 502 instead of the chipset 504. In some embodiments, the computer 500 includes one or more communication buses for interconnecting these components. The one or more communication buses optionally include circuitry (sometimes called a chipset) that interconnects and controls communications between system components.


The storage device 508 is any non-transitory computer-readable storage medium, such as a hard drive, compact disk read-only memory (CD-ROM), DVD, or a solid-state memory device or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Such a storage device 508 can also be referred to as persistent memory. The pointing device 514 may be a mouse, track ball, or other type of pointing device, and is used in combination with the keyboard 510 to input data into the computer 500. The graphics adapter 512 displays images and other information on the display 518. The network adapter 516 couples the computer 500 to a local or wide area network.


The memory 506 holds instructions and data used by the processor 502. The memory 506 can be non-persistent memory, examples of which include high-speed random access memory, such as DRAM, SRAM, DDR RAM, ROM, EEPROM, flash memory.


As is known in the art, a computer 500 can have different or other components than those shown in FIG. 5. In addition, the computer 500 can lack certain illustrated components. In one embodiment, a computer 500 acting as a server may lack a keyboard 510, pointing device 514, graphics adapter 512, or display 518. Moreover, the storage device 508 can be local or remote from the computer 500 (such as embodied within a storage area network (SAN)).


As is known in the art, the computer 500 is adapted to execute computer program modules for providing functionality described herein. As used herein, the term “module” refers to computer program logic utilized to provide the specified functionality. Thus, a module can be implemented in hardware, firmware, or software. In one embodiment, program modules are stored on the storage device 508, loaded into the memory 506, and executed, individually or together, by one or more processors (e.g., 502).


Additional Considerations

The disclosure above describes example embodiments for purposes of illustration only. Any features that are described as essential, important, or otherwise implied to be required should be interpreted as only being required for that embodiment and are not necessarily included in other embodiments.


Some portions of above disclosure describe the embodiments in terms of algorithmic processes or operations. These algorithmic descriptions and representations are commonly used by those skilled in the computing arts to convey the substance of their work effectively to others skilled in the art. These operations, while described functionally, computationally, or logically, are understood to be implemented by computer programs comprising instructions for execution, individually or together, by one or more processors, equivalent electrical circuits, microcodes, or the like. Furthermore, it has also proven convenient at times, to refer to these arrangements of functional operations as modules, without loss of generality. In some cases, a module can be implemented in hardware, firmware, or software.


As used herein, any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment. Similarly, use of “a” or “an” preceding an element or component is done merely for convenience. This description should be understood to mean that one or more of the elements or components are present unless it is obvious that it is meant otherwise. As used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).


In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments. This is done merely for convenience and to give a general sense of the disclosure. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise. Where values are described as “approximate” or “substantially” (or their derivatives), such values should be construed as accurate +/−10% unless another meaning is apparent from the context. From example, “approximately ten” should be understood to mean “in a range from nine to eleven.”


Alternative embodiments are implemented in computer hardware, firmware, software, and/or combinations thereof. Implementations can be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor system including one or more processors that can act individually or together; and method steps can be performed by a programmable processor system executing a program of instructions to perform functions by operating on input data and generating output. Embodiments can be implemented advantageously in one or more computer programs that are executable on a programmable system including one or more programmable processors coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Each computer program can be implemented in a high-level procedural or object-oriented programming language, or in assembly or machine language if desired; and in any case, the language can be a compiled or interpreted language. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random-access memory. Generally, a computer will include one or more mass storage devices for storing data files; such devices include magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and optical disks. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM disks. Any of the foregoing can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits) and other forms of hardware.


Although the above description contains many specifics, these should not be construed as limiting the scope of the disclosure but merely as illustrating different examples. It should be appreciated that the scope of the disclosure includes other embodiments not discussed in detail above. Various other modifications, changes, and variations which will be apparent to those skilled in the art may be made in the arrangement, operation, and details of the methods and apparatuses disclosed herein without departing from the spirit and scope of the disclosure.

Claims
  • 1. A method comprising: receiving a function ƒ(x) describing a value of an object, values of x, and probabilities p(x) for the values of x;receiving a quantum operator P that, when executed by a first quantum computing system, creates a first quantum state characterized by a superposition of states encoding the x values, where the amplitude for a corresponding x value is the square root of the probability p(x) for that x value;determining a quantum operator U+{right arrow over (ϕ)} that, when executed by a second quantum computing system, encodes an approximation of the function ƒ(x) in an amplitude of a second quantum state without calculating |ƒ(x) for any of the values of x, the approximation being within an error threshold of the function ƒ(x);instructing a third quantum computing system to execute both of the quantum operators P and U+{right arrow over (ϕ)} to generate a third quantum state on a register of qubits, one of the amplitudes of the third quantum state including probabilities p(x) for the values of x and output values of the approximation of the function ƒ(x) for the values of x; anddetermining the value of the object based on the generated third quantum state.
  • 2. The method of claim 1, wherein the method does not include calculating |ƒ(x).
  • 3. The method of claim 1, wherein the one of the amplitudes of the third quantum state is the square root of the weighted average of the approximation of the function ƒ(x) for the x values where the weights are the probabilities p(x) for the corresponding values of x.
  • 4. The method of claim 1, wherein the first quantum state is given by Σx√{square root over (p(x))}|x, where |x is a quantum state on an n-qubit register storing an n-bit binary representation of the corresponding value of x.
  • 5. The method of claim 1, further comprising: determining s, where s is based on the absolute values of the x values; andinstructing the third quantum computing system to apply a quantum binary addition circuit that performs the operation: |x|0→|x|x+s, where n and m are integers greater than zero, m>n, |x is a quantum state on an n-qubit register storing an n-bit binary representation of a value of x, and |x+s is a quantum state on an m-qubit register storing a representation of a value of x+s with m total digits and p digits to the left of the binary point.
  • 6. The method of claim 5, wherein s is the absolute value of the smallest x value of the values of x.
  • 7. The method of claim 1, wherein determining the quantum operator U+{right arrow over (ϕ)}, comprises generating an initial quantum operator given by U=C(⊗H⊗m⊗), where C is a comparator quantum circuit defined by C:|a|b|0→|a|b|a<b, is an identity matrix, and H is a Hadamard gate.
  • 8. The method of claim 7, wherein determining the quantum operator U+{right arrow over (ϕ)} further comprises applying the initial quantum operator U to state |x+s|0m+1 to generate the following quantum state:
  • 9. The method of claim 8, wherein determining the quantum operator U+{right arrow over (ϕ)} further comprises performing a quantum signal processing (QSP) algorithm.
  • 10. The method of claim 9, wherein performing the QSP algorithm includes determining phase parameters representing a polynomial approximation that approximates
  • 11. A non-transitory computer readable storage medium storing instruction that, when executed by a computing system, cause the computing system to perform operations comprising: receiving a function ƒ(x) describing a value of an object, values of x, and probabilities p(x) for the values of x;receiving a quantum operator P that, when executed by a first quantum computing system, creates a first quantum state characterized by a superposition of states encoding the x values, where the amplitude for a corresponding x value is the square root of the probability p(x) for that x value;determining a quantum operator U+{right arrow over (ϕ)} that, when executed by a second quantum computing system, encodes an approximation of the function ƒ(x) in an amplitude of a second quantum state without calculating |ƒ(x) for any of the values of x, the approximation being within an error threshold of the function ƒ(x);instructing a third quantum computing system to execute both of the quantum operators P and U+{right arrow over (ϕ)} to generate a third quantum state on a register of qubits, one of the amplitudes of the third quantum state including probabilities p(x) for the values of x and output values of the approximation of the function ƒ(x) for the values of x; anddetermining the value of the object based on the generated third quantum state.
  • 12. The non-transitory computer readable storage medium of claim 11, wherein the operations do not include calculating |ƒ(x).
  • 13. The non-transitory computer readable storage medium of claim 11, wherein the one of the amplitudes of the third quantum state is the square root of the weighted average of the approximation of the function ƒ(x) for the x values where the weights are the probabilities p(x) for the corresponding values of x.
  • 14. The non-transitory computer readable storage medium of claim 11, wherein the first quantum state is given by Σx√{square root over (p(x))}|x, where |x is a quantum state on an n-qubit register storing an n-bit binary representation of the corresponding value of x.
  • 15. The non-transitory computer readable storage medium of claim 11, wherein the operations further comprise: determining s, where s is based on the absolute values of the x values; andinstructing the third quantum computing system to apply a quantum binary addition circuit that performs the operation: |x|0→|x|x+s, where n and m are integers greater than zero, m>n, |x is a quantum state on an n-qubit register storing an n-bit binary representation of a value of x, and |x+s is a quantum state on an m-qubit register storing a representation of a value of x+s with m total digits and p digits to the left of the binary point.
  • 16. The non-transitory computer readable storage medium of claim 15, wherein s is the absolute value of the smallest x value of the values of x.
  • 17. The non-transitory computer readable storage medium of claim 11, wherein determining the quantum operator U+{right arrow over (ϕ)}, comprises generating an initial quantum operator given by U=C(⊗H⊗m⊗), where C is a comparator quantum circuit defined by C:|a|b|0→|a|b|a<b, is an identity matrix, and His a Hadamard gate.
  • 18. The non-transitory computer readable storage medium of claim 17, wherein determining the quantum operator U+{right arrow over (ϕ)} further comprises applying the initial quantum operator U to state |x+s|0 to generate the following quantum state:
  • 19. The non-transitory computer readable storage medium of claim 18, wherein determining the quantum operator U+{right arrow over (ϕ)} further comprises performing a quantum signal processing (QSP) algorithm.
  • 20. The non-transitory computer readable storage medium of claim 19, wherein performing the QSP algorithm includes determining phase parameters representing a polynomial approximation that approximates
Priority Claims (1)
Number Date Country Kind
20230100473 Jun 2023 GR national
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims priority to, and the benefit of, U.S. Provisional Patent Application Ser. No. 63/522,277 “Derivative Pricing using Quantum Signal Processing” filed Jun. 21, 2023 and Greek patent application No. 20230100473 filed on Jun. 14, 2023, each of which are incorporated by reference in their entirety.

Provisional Applications (1)
Number Date Country
63522277 Jun 2023 US