QUANTUM INTERIOR POINT METHOD

Information

  • Patent Application
  • 20240144066
  • Publication Number
    20240144066
  • Date Filed
    October 04, 2023
    a year ago
  • Date Published
    May 02, 2024
    9 months ago
  • CPC
    • G06N10/20
    • G06N10/60
  • International Classifications
    • G06N10/20
    • G06N10/60
Abstract
In some aspects, the techniques described herein relate to a quantum method for solving a second-order cone program (SOCP) instance, the method including: defining a Newton system for the SOCP instance by constructing matrix G and vector h based on the SOCP instance; preconditioning matrix G and vector h via row normalization to reduce a condition number of matrix G; iteratively determining u until a predetermined iteration condition is met, the iterations including: causing a quantum computing system to apply matrix G and vector h to a quantum linear system solver (QLSS) to generate a quantum state; causing the quantum computing system to perform quantum state tomography on the quantum state; and updating a value of u based on a current value of u and the output of the quantum state tomography; and determining a solution to the SOCP instance based on the updated value of u.
Description
BACKGROUND
1. Technical Field

This disclosure relates generally to quantum interior point methods (QIPMs), and more particularly to implementing quantum interior point methods (QIPMs).


2. Description of Related Art

The practical utility of finding optimal solutions to well-posed optimization problems has been known since the days of antiquity. With the advent of the quantum era, there has been great interest in developing quantum algorithms that solve optimization problems with provable speedups over classical algorithms. Unfortunately, it can be difficult to implement these quantum algorithms and evaluate whether these quantum algorithms will be practically useful.


SUMMARY

In some aspects, the techniques described herein relate to a quantum interior point method (QIPM) for solving a second-order cone program (SOCP) instance using a quantum computing system, the method including: receiving the SOCP instance; defining a Newton system for the SOCP instance by constructing matrix G and vector h, where matrix G and vector h describe constrains for a linear system Gu=h based on the SOCP instance; preconditioning matrix G and vector h via row normalization to reduce a condition number of matrix G; iteratively determining u until a predetermined iteration condition is met, the iterations including: causing the quantum computing system to apply matrix G and vector h to a quantum linear system solver (QLSS) to generate a quantum state; causing the quantum computing system to perform quantum state tomography on the quantum state; and updating a value of u based on a current value of u and the output of the quantum state tomography; and determining a solution to the SOCP instance based on the updated value of u.


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





BRIEF DESCRIPTION OF THE DRAWINGS

Embodiments of the disclosure have 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 a diagram of an example quantum circuit configured to enact a unitary U[s] on registers on a set of registers, according to some embodiments;



FIG. 2 is a diagram of an example Quantum singular value transform (QSVT) circuit, according to some embodiments;



FIG. 3 is a diagram of an example-controlled version of the quantum circuit in FIG. 1, controlled on qubit c, according to some embodiments;



FIG. 4 is a diagram illustrating an example decomposition of the UQh gate into a state-preparation unitary Uh and multi-controlled-Toffoli gates, according to some embodiments;



FIG. 5 is a diagram illustrating an example decomposition of the CR0(s) gate (top) and controlled-CR0(s) gate (bottom), as defined in eq. (55), according to some embodiments;



FIG. 6 is a diagram illustrating an example decomposition of the VG unitary (top) and controlled-VG unitary (bottom), as defined in eq. (57), according to some embodiments;



FIG. 7 is a plot illustrating simulation results of the QIPM on an SOCP instance corresponding to portfolio optimization on 30 randomly chosen stocks, according to some embodiments;



FIG. 8 includes plots of the Median Frobenius condition number for 128 randomly sampled stock portfolios from the DWCF index, according to some embodiments;



FIG. 9 is a plot of the Median Frobenius condition number κF for 128 randomly sampled stock portfolios from the DWCF index, according to some embodiments;



FIG. 10 is a plot of the median value of the square of the inverse tomography precision used to remain in the neighborhood of the central path for 128 randomly sampled stock portfolios from the DWCF index, according to some embodiments;



FIG. 11 is a plot of the median value of the estimated algorithm scaling factor, according to some embodiments;



FIG. 12 is a diagram illustrating the breakdown of quantum resources used for a single coherent run of the uncontrolled version of a quantum algorithm, according to some embodiments;



FIG. 13 includes two plots of the Median Frobenius condition number for 128 randomly sampled stock portfolios from the DWCF index, according to one or more embodiments;



FIG. 14 includes two plots of the Median value of the square of the required inverse tomography precision used to remain in the neighborhood of the central path for 128 randomly sampled stock portfolios from the DWCF index, according to one or more embodiments;



FIG. 15 includes two plots of the Median value of the estimated algorithm scaling factor computed as the median of n1.5κF2 for 128 randomly sampled stock portfolios from the DWCF index, according to one or more embodiments;



FIG. 16 is a flowchart of an example method, specifically a quantum interior point method (QIPM), for solving a second-order cone program (SOCP) instance using a quantum computing system, according to one or more embodiments;



FIGS. 17A-17B are block diagrams of a computing system including a classical computing system and a quantum computing system, according to some embodiments;



FIG. 17C-17D are block diagrams of components of a quantum computing system, according to some embodiments;



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



FIG. 18 is an example architecture of a classical computing system, according to some embodiments.





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.


I. OVERVIEW

This disclosure studies quantum interior point methods (QIPMs) for second-order cone programming (SOCP), guided by the example use case of portfolio optimization (PO). This disclosure provides a complete quantum circuit-level description of the algorithm from problem input to problem output, making several improvements to the implementation of the QIPM. This disclosure reports the number of logical qubits and the quantity/depth of non-Clifford T-gates used to run the algorithm, including constant factors. The determined resource counts depend on instance-specific parameters, such as the condition number of certain linear systems within the problem. To determine the size of these parameters, numerical simulations of small PO instances are performed, which lead to concrete resource estimates for the PO use case. The numerical results do not probe large enough instance sizes to make conclusive statements about the asymptotic scaling of the algorithm. However, already at small instance sizes, the analysis suggests that, due primarily to large constant pre-factors, poorly conditioned linear systems, and a fundamental reliance on costly quantum state tomography, fundamental improvements to the QIPM are desired for it to lead to practical quantum advantage.


A. Introduction

The practical utility of determining optimal solutions to well-posed optimization problems has been known since the days of antiquity, with Euclid considering the minimal distance between two points using a line. In the modern era, optimization algorithms for business and financial use cases continue to be ubiquitous. Partly as a result of this utility, algorithmic techniques for optimization problems have been well studied since even before the invention of the computer, including a famous dispute between Legendre and Gauss on who was responsible for the invention of least squares fitting. With the advent of the quantum era, there has been great interest in developing quantum algorithms that solve optimization problems with provable speedups over classical algorithms.


Unfortunately, it can be difficult to evaluate whether these quantum algorithms will be practically useful. In some cases, the algorithms are heuristic, and their performance can only be measured empirically once it is possible to run them on actual quantum hardware. In other cases, the difficulty in evaluating practicality stems from the inherent complexity of combining many distinct ingredients, each with their own caveats and bottlenecks. To make an apples-to-apples comparison and quantify advantages of a quantum algorithm, an end-to-end resource analysis that accounts for all costs from problem input to problem output may be performed.


Such an end-to-end analysis for a quantum interior point method (QIPM) was performed for solving second-order cone programs (SOCPs). In particular, this disclosure focuses on a concrete use case with very broad applications, but of interest in the financial services sector: portfolio optimization (PO). In general, PO is the task of determining the optimal resource allocation to a collection of possible classes to optimize a given objective. In finance, one seeks to determine the optimal allocation of funds across a set of possible assets that maximizes returns and minimizes risk, subject to constraints. Noteworthy, many variants of the PO problem can be cast as a SOCP and subsequently solved with a classical or quantum interior point method. Indeed, classical interior point methods (CIPMs) are efficient not only in theory, but also in practice; they are the method of choice within fast numerical solvers for SOCPs and other conic programs, which encompass a large variety of optimization problems that appear in industry. Notably, QIPMs structurally mirror CIPMs, and seek improvements by replacing certain subroutines with quantum primitives. Thus, compared to other proposed quantum algorithms for conic programs not based on widely used classical techniques (e.g., solvers that leverage the multiplicative weights update method), QIPMs are uniquely positioned to provide not only a theoretical asymptotic advantage, but also a practical quantum solution for this common class of problem.


However, the QIPM is a complex algorithm that delicately combines some purely classical steps with multiple distinct quantum subroutines. The runtime of the QIPM is stated in terms of several parameters that can only be evaluated once a particular use case has been specified; depending on how these parameters scale, an asymptotic speedup may or may not be achievable. Additionally, any speedup is contingent on access to a large quantum random access memory (QRAM), an ingredient that in prior asymptotic-focused analyses has typically been assumed to exist without much further justification or cost analysis.


The resource analysis is detailed and takes care to study aspects of the end-to-end pipeline, including the QRAM component. This disclosure reports results in terms of relevant problem parameters, and then describes numerical experiments to determine the size and scaling of these parameters for actual randomly chosen instances of the PO problem, based on historical stock data. This approach allows us to estimate the exact resource cost of the QIPM for an example PO problem, including a detailed breakdown of costs by various subroutines. This estimate incorporates several optimizations to the underlying subroutines, and technical improvements to how they are integrated into the QIPM. Consequently, our analysis allows us to evaluate the prospect that the algorithm may exhibit a practical quantum advantage, and it reveals the computational bottlenecks within the algorithm that are most in need of further improvement.


While this disclosure focuses on the QIPM and its application to the PO problem, this disclosure has more general applications and more general takeaways for quantum algorithms and for quantum computing applications. Firstly, the results emphasize the importance of end-to-end analysis when evaluating a proposed application. Furthermore, the modular treatment of the underlying algorithmic primitives produces quantitative and qualitative takeaways that are relevant for end-to-end treatments of a large number of other algorithms that also rely on these subroutines, especially those in the area of machine learning, where data access via QRAM and quantum linear algebra techniques are often used.


B. Results

The resource analysis focuses on three central quantities that determine the overall cost of algorithms implemented on fault-tolerant quantum computers: the number of logical qubits, the total number of T gates (“T-count”), and the number of parallel layers of T gates (“T-depth”) useed to construct quantum circuits for solving the problem. The T-depth acts as a proxy for the overall runtime of the algorithm, whereas the T-count and number of logical qubits are helpful for determining how many physical qubits may be used for a full, fault-tolerant implementation. We justify the focus on T gates by pointing out that, in many prominent approaches to fault-tolerant quantum computation, quantum circuits are decomposed into Clifford gates and T gates, and the cost of implementing the circuit is dominated by the number and depth of the T gates. The fault-tolerant Clifford gates can be performed transversally or even in software, whereas the T gates use the expensive process of magic state distillation. This disclosure stops short of a full analysis of the algorithm at the physical level, as the logical analysis seems to suffice to evaluate the overall outlook for the algorithm and identify its main bottlenecks.


At the core of any interior point method (IPM) is the solving of a linear system of equations. The QIPM performs this step using a quantum linear system solver (QLSS) together with pure state quantum tomography. The cost of QLSS depends on a parameter κF, the Frobenius condition number ∥G∥F∥G−1∥ of the matrix G that is inverted (where ∥⋅∥F denotes the Frobenius norm, and ∥⋅∥ denotes the spectral norm), while the cost of tomography depends on a parameter ξ, a precision parameter. These parameters are evaluated empirically by simulating the QIPM on small instances of the PO problem.


Table I reports a summary of overall resource calculation, in which the asymptotically leading term is shown (along with its constant prefactor) in terms of parameters κF and ξ, as well as n, the number of assets in the PO instance, and ∈, the desired precision to which the portfolio should be optimized. It is determined (numerically) that κF grows with n, and that ξ shrinks with n; it is estimated that, at n=100 and ∈=10−7, the implementation of the QIPM may use 8×106 qubits and 8×1029 total T gates spread out over 2×1024 layers. These resource counts are decidedly out of reach both in the near and far term for quantum hardware, even for a problem of modest size by classical standards. Even if quantum computers one day match the gigahertz-level clock-speeds of modern classical computers, 1024 layers of T gates would take millions of years to execute. By contrast, the PO problem can be easily solved in a matter of seconds on a laptop for n=100 stocks.


This disclosure cautions that the numbers reported should not be interpreted as the final word on the cost of the QIPM for PO. Further examination of the algorithm may uncover many improvements and optimizations that may reduce the costs compared to the current calculations. On the other hand, the results do already incorporate several innovations made to reduce the resource cost, including preconditioning the linear system.


Besides the main resource calculation, this disclosure makes several additional contributions and observations:

    • 1. This disclosure provides explicit example quantum circuits for useful (e.g., important) subroutines of the QIPM, namely the state-of-the-art QLSS based on the discrete adiabatic theorem and pure state tomography, which complement the circuits for block-encoding (using QRAM). These example quantum circuits, and their precise resource calculations, may be useful elsewhere, as these subroutines are ubiquitous in quantum algorithms. See section IV F and section V for additional details.
    • 2. This disclosure breaks down the resource calculation into its constituents to illustrate which parts of the algorithm are most costly. This disclosure determines that many independent factors create significant challenges toward realizing quantum advantage with QIPMs, and this work underscores aspects of the algorithm that may be improved. This disclosure also notes that the conditions under which QIPMs would be most successful (e.g., when κF is small) also allow for classical IPMs based on iterative classical linear system solvers to be competitive. See section VII for additional details.
    • 3. This disclosure numerically simulates several versions of the full QIPM solving the PO problem on portfolios as large as n=120 stocks, and this disclosure reports the empirical size and scaling of the relevant parameters κF and ξ. There is considerable variability in the trends observes, depending on which version of the QIPM is chosen, and when the QIPM is terminated, which makes it difficult to draw robust conclusions. However, this disclosure determines that both κF and ξ−1 appear to grow with n. Note that previous numerical experiments on a similar formulation of the PO problem suggested κF does not grow with problem size, but those pervius experiments scaled the number of “time epochs” while keeping n constant. Additionally, this disclosure observes that the “infeasible” version of the QIPM originally empirically performs similarly to more sophisticated “feasible” versions, despite not enjoying the same theoretical guarantees of fast convergence. Finally, contrary to theoretical expectation, this disclosure observes that κF and ξ−1 do not diverge as ∈→0. See section VI for additional details.
    • 4. This disclosure makes various technical improvements to the underlying ingredients of QIPMs:
    • Tomographic precision: Performing tomography on the output of a QLSS necessarily causes the classical estimate of the solution to the linear system to be inexact. This disclosure describes how the allowable amount of tomography precision can be determined adaptively rather than relying on theoretical bounds. Nonetheless, this disclosure also improves the constant prefactor in the tomographic bounds. The total number of state preparation queries used to learn an unknown L-dimensional pure state to ξ error using a tomography method is to leading order at most 115L ln(L)/ξ2.
    • Norm of the linear system: Since QLSSs output a normalized quantum state, tomography does not directly yield the norm of the solution to the linear system. The norm can be learned through more complicated protocols, but it is observed that in the context of QIPMs, a sufficient estimate for the norm can be learned classically.
    • Preconditioning: a preconditioning method is proposed that is compatible with the QIPM, while reducing the parameter κF. The numerical simulations suggest the reduction is more than an order of magnitude for the portfolio optimization problem.
    • Feasible QIPM: A “feasible” version of a QIPM is implemended which includes determining a basis for the null space of the SOCP matrix. This disclosure identifies an explicit basis for the PO problem, thereby avoiding a costly QR decomposition. However, this disclosure observes that determines the basis via QR decomposition leads to more stable numerical results.


      TABLE I illustrates asymptotic, leading-order contributions to the total quantum resources for an end-to-end portfolio optimization (including constant factors), in terms of the number of assets in the portfolio (n), the desired precision to which the portfolio should be optimized (∈), the maximum Frobenius condition number of matrices encountered by the QIPM (κF), and the minimum tomographic precision for the algorithm to succeed (ξ). The T-depth and T-count expressions represent the cumulative cost of custom-character−2 n1.5 log(n)log(∈−1)) individual quantum circuits performed serially, a quantity that we estimate evaluates to 6×1012 circuits at n=100; see table X for a detailed accounting. The right column uses a numerical simulation of the quantum algorithm (see section VI) to compute the instance-specific parameters in the resource expression and estimate the resource cost at n=100 and ∈=10−7.











TABLE I





Resource
QIPM complexity
Estimated at n = 100







Number of logical qubits
800 n2
8 × 106





T-depth





(

2
×
1


0

1

0



)



κ
F



n
1.5



ξ

-
2





log
2

(
n
)




log
2

(

ϵ

-
1


)




log
2

(


κ
F



n

14
/
27




ξ

-
1



)





2 × 1024





T-count





(

7
×
1


0

1

1



)



κ
F



n

3
.
5




ξ

-
2






log

2



(
n
)





log

2



(

ϵ

-
1


)




log
2




(


κ
F



ξ

-
1



)





8 × 1029









The outline for the remainder of this disclosure is as follows. Section II describes and defines the portfolio optimization problem in terms of Markowitz portfolio theory. Section III describes Second Order Cone Programming (SOCP) problems, illustrate how portfolio optimization can be represented as an instance of SOCP, and discuss how IPMs can be used for solving SOCPs. Section IV review the quantum ingredients used to turn an IPM into a QIPM. In particular, this disclosure reviews quantum linear system solvers, block-encoding for data loading, and quantum state tomography for data read out. This disclosure also presents better bounds on the tomography procedure than were previously known. Section V describes the implementation of using QIPM and quantum algorithms for SOCP for the portfolio optimization problem, including a detailed resource estimate for the end-to-end problem. Section VI shows numerical results from simulations of the full problem, and section VII reflects on the calculations performed, identifying the main bottlenecks and drawing conclusions about the outlook for quantum advantage with QIPM.


The QIPM has many moving parts using several mathematical symbols. While all symbols are defined as they are introduced in the text, this disclosure also provides a full list of symbols for the reader's reference in the section Additional Information A. Throughout the paper, all vectors are denoted in bold lowercase letters to contrast with scalar quantities (unbolded lowercase) and matrices (unbolded uppercase). The only exception to this rule will be the symbols N, K, and L, which are positive integers (despite being uppercase), and denote the number of rows or columns in certain matrices related to an SOCP instance.


II. PORTFOLIO OPTIMIZATION (PO)
A. Introduction

Portfolio optimization is the process widely used, for example, by financial analysts to assign allocations of capital across a set of assets within a portfolio, given optimization criteria such as maximizing the expected return and minimizing the financial risk. The creation of the mathematical framework for modern portfolio theory (MPT) is credited to Harry Markowitz, for which he received the 1990 Alfred Nobel Memorial Prize in Economic Sciences. Markowitz describes the process of selecting a portfolio in two stages, where the first stage starts with “observation and experience” and ends with “beliefs about the future performances of available securities.” The second stage starts with “the relevant beliefs about future performances” and ends with “the choice of portfolio.” The theory is also known as mean-variance analysis.


Typically, portfolio optimization strategies include diversification, which is the practice of investing in a wide array of asset types and classes as a risk mitigation strategy. Some popular asset classes are stocks, bonds, real estate, commodities, and cash. After building a portfolio, one may expect a return (or profit) after a specific period of time. Risk is defined as the fluctuations of the asset value. MPT describes how high variance assets can be combined with other uncorrelated assets through diversification to create portfolios with low variance on their return. Naturally, among equal-risk portfolios, investors prefer those with higher expected return, and among equal-return portfolios, they prefer those with lower risk.


B. Mathematical Formulation

Within a portfolio, wi represents the amount of an asset i being held over some period of time. Often, this amount is given as the asset's price in dollars at the start of the period. When the price is positive (wi>0), this is referred to as a long position; and when the price is negative (wi<0), this is referred to as a short position with an obligation to buy this asset at the end of the period. Typically, investment banks hold long positions, while hedge funds build portfolios with short positions that have higher risk due to the uncertainty of the price to buy the asset at the end of the period. The optimization variable in the portfolio optimization problem is the vector of n assets w∈custom-character in the portfolio.


The price of each asset i varies over time. ui is defined to be the relative change (positive or negative) during the period of interest. Then, the return of the portfolio for that period is defined as r=uTw dollars. The relative changes u∈custom-character follow a stochastic process, and this can be modeled with a random vector with mean û and covariance Σ. The return r is then a random variable with mean ûTw and covariance wTΣw.


To capture realistic problem formulations, one or more mathematical constraints may be added to the optimization problem corresponding to the problem-specific considerations. For example, two common constraints in portfolio optimization problems are no short positions (wi≥0 for all i, denoted by w≥0) and that the total investment budget is limited (1Tw=1, where 1 denotes the vector of ones). This forms the classical portfolio optimization problem from Markowitz's mean-variance theory:












min
w





w





w








(
1
)












s
.
t
.







u
^




w




r
¯

min












1



w

=
1






w

0




This formulation is a quadratic optimization problem where risk is minimized, while achieving a target return of at least fmin with a fixed budget and no short positions. In practice, the portfolio optimization problem is often reformulated in other ways, for example, to maximize return subject to a fixed amount of risk, or to optimize an objective function that weighs risk against return. The current application follows the latter approach, formulated as follows, where q is a tunable risk-aversion coefficient:












min
w






-


u
^





w

+

q




w





w











(
2
)












s
.
t
.






1



w

=
1









w

0




This optimization problem is no longer a QO problem, but it can be mapped to a conic problem, as described later in section III B. Depending on the problem, additional constraints can be added. For instance, constraints can be added to allow short positions, component-wise short sale limits, or a total short sale limit. Another variant of this is a constraint for a collateralization requirement, which limits the total of short positions to a fraction of the total long positions. Often, buying or selling an asset results in a transaction fee that is proportional to the amount of asset that is bought or sold. Linear transaction costs or maximum transaction amounts are often included as constraints in portfolio optimization. Diversification constraints can limit portfolio risk by limiting the exposure to individual positions and groups of assets within particular sectors. To illustrate the flexibility of this analysis, a maximum transaction constraint is included and use the following problem formulation is used in the analysis in the rest of the disclosure:












min
w






-


u
^





w

+

q




w





w











(
3
)












s
.
t
.






1



w

=
1












"\[LeftBracketingBar]"


w
-

w
¯




"\[RightBracketingBar]"



ζ







w

0

,




where w denotes the current portfolio, so that |w−w| is the vector of transaction quantities for each asset, which are constrained to be smaller than maximum values contained in the vector ζ.


III. SECOND ORDER CONE PROGRAMMING (SOCP) AND INTERIOR POINT METHODS (IPM)
A. Definitions

Second-order cone programming (SOCP) is a type of convex optimization that allows for a richer set of constraints than linear programming (LP), without many of the complications of semidefinite programming (SDP). Indeed, SOCP is a subset of SDP, but SOCP admits interior point methods (IPMs) that may be just as efficient as IPMs for LP. Many real-world problems can be cast as SOCP, including the example portfolio optimization problem of interest.


For any k-dimensional vector v, the following may be used v=(v0; {tilde over (v)}), where v0 is the first entry of v, and {tilde over (v)} contains the remaining k−1 entries.


Definition 1. A k-dimensional second-order cone (for k≥2) is the convex set






custom-character={(x0;{tilde over (x)})∈custom-character|x0≥∥{tilde over (x)}∥},  (4)


where ∥⋅∥ denotes the vector two-norm (standard Euclidean norm). For k=1, custom-character={x0custom-character|x0≥0}.


Definition 2. In general, a second-order cone problem is formulated as












min
x





c



x







(
5
)












s
.
t
.




Ax
=
b










x

𝒬

,




where custom-character=custom-character× . . . ×custom-character is a Cartesian product of r second-order cones of combined dimension N=N1+ . . . +Nr, and A is a full-rank K×N matrix encoding K linear equality constraints, with K≤N.


Note that the special case of linear programming is immediately recovered if Ni=1 for all i. We say that a point x is primal feasible whenever Ax=b and x∈custom-character. It is strictly primal feasible if additionally it lies in the interior of custom-character.


The dual to problem in eq. (5) is a maximization problem over a variable y∈custom-character, given as follows:












min
y





b



y







(
6
)












s
.
t
.







A



y

+
s

=
c









s


𝒬
.





We say that a pair (s; y) is dual feasible whenever ATy+S=c and s∈custom-character. For any point (x; y; s) with x, s∈custom-character, the duality gap may be defined as











μ

(

x
,
s

)

:=



1
r



x



s

=


1
r



(



c



x

-


b



y


)




,




(
7
)







where r is the number of cones, as in definition 2, and the second equality holds under the additional assumption that the point is primal and dual feasible. The fact that x, s∈custom-character implies that μ(x, s)≥0. Moreover, assuming that both the primal and dual problems have a strictly feasible point, the optimal primal solution x* and the optimal dual solution (y*; s*) are guaranteed to exist and satisfy cTx*=bTy*, and hence






μ
=



1
r



x

*





s
*


=



x

*



(

c
-


A




y
*



)

=




c




x
*


-


b




y
*



=

0
.








Thus, the primal-dual condition of optimality can be expressed by the system






Ax=b






A
T
y+s=c






x
T
s=0






x∈
custom-character
,s∈
custom-character
.  (8)


B. Portfolio Optimization as SOCP

The portfolio optimization problem can be solved by reduction to SOCP, and this reduction is often made in practice. Here this disclosure describes one way of translating the portfolio optimization problem, as given in eq. (3) into a second-order cone program.


The objective function in eq. (3) has a non-linear term q√{square root over (wTΣw)}, which may be linearized by introducing a new scalar variable t, and a new constraint t≥√{square root over (wTΣw)}. This results in the equivalent optimization problem












min

x
=

(

w
;
t

)








[


-

u
^


;
q

]





(

w
;
t

)








(
9
)












s
.
t
.






1



w

=
1












"\[LeftBracketingBar]"



w
i

-


w
¯

i




"\[RightBracketingBar]"




ζ
i








w
i


0







t
2




w






w
.







A goal now is to express the constraints in eq. (9) as second-order cone constraints. Given an m×n matrix M for which Σ=MTM, the constraint on t can be expressed by introducing an m-dimensional variable η subject to the equality constraint η=Mw and the second-order cone constraint (t; η) ∈custom-character.


The matrix M can be determined from Σ via a Cholesky decomposition, although for large matrices Σ, this computation may be costly. Alternatively, if Σ and {circumflex over (μ)} are calculated from stock return vectors u(1), . . . , u(m) during m independent time epochs (e.g. returns for each of m days or each of m months), then a valid matrix MT is given by (u(1)−û, . . . , u(m)−û), i.e. the columns of MT are given by the deviation of the returns from the mean in each epoch. This is the approach taken in the numerical experiments herein (presented later).


The absolute value constraints are handled by introducing a pair of n-dimensional variables ϕ and ρ, subject to equality constraints ϕ=ζ−(w−w) and ρ=ζ+(w−w). The absolute value constraints are then imposed as positivity constraints ϕi≤0, ρi≥0, which are included as second-order cone constraints of dimension 1. Alternatively, the absolute value constraints may be encoded with n second-order cone constraints of dimension 2; these formulations are equivalent up to a simple coordinate change, and one may opt to use 1-dimensional cones for their simplicity of presentation.


In summary, the portfolio optimization problem from eq. (3) may be described as the following SOCP that minimizes over the variable x=(w; ϕ; ρ; t; η) ∈custom-character












min
x







[


-

u
^


;
0
;
0
;
q
;
0

]





(

w
;
ϕ
;
ρ
;
t
;
η

)


=

:


c



x









(
10
)












s
.
t
.






(




1





0





0




0



0






I


I


0


0


0




I


0



-
I



0


0




M


0


0


0



-
I




)




(



w




ϕ




ρ




t




η



)


=

(



1






w
¯

+
ζ







w
¯

-
ζ





0



)














(

w
;
ϕ
;
ρ
;
t
;
η

)









𝒬
1

×

×

𝒬
1





n


positivity


constraints










×




𝒬
1

×

×

𝒬
1





2

n


budget


constraints








×




𝒬

m
+
1


,



risk





where I denotes an identity block, 0 denotes a submatrix of all 0s, 0 is a vector of all 0s, 1 is a vector of all 1s, and the size of each block of A can be inferred from its location in the matrix. Thus, the total number of cones is r=3n+1, and the combined dimension is N=3n+m+1. Note that r=2n+1 cones if the absolute value constraints are represented using dimension-2 cones. The SOCP constraint matrix A is a K×N matrix, with K=2n+m+1.


Notice that many of the rows of the K×N matrix A are sparse and contain only one or two nonzero entries. However, the final m rows of the matrix A will be dense and contain n+1 nonzero entries due to the appearance of the matrix M containing historical stock data; in total a constant fraction of the matrix entries will be nonzero, so sparse matrix techniques will provide only limited benefit.


Additionally, note that the primal SOCP in eq. (10) has an interior feasible point as long as (has strictly positive entries. To better understand this, choose w to be any strictly positive vector that satisfies |w−w|<ζ, and let ϕ=ζ+(w−w), ρ=ζ−(w−w), η=Mw, and t equal to any number strictly greater than ∥η∥. It can be verified that the dual program likewise has a strictly feasible point; this guarantees that the optimal primal-dual pair for the SOCP exists and satisfies eq. (8).


C. Interior Point Methods for SOCP
1. Introduction

Interior point methods (IPMs) are a class of efficient algorithms for solving convex optimization problems including LPs, SOCPs, and SDPs, where (in contrast to the simplex method) intermediate points generated by the method lie in the interior of the convex set, and they are guaranteed to approach the optimal point after a polynomial number of iterations of the method. Each iteration involves forming a linear system of equations that depends on the current intermediate point. The solution to this linear system determines the search direction, and the next intermediate point is formed by taking a small step in that direction. This disclosure considers path-following primal-dual IPMs, where, if the step size is sufficiently small, the intermediate points are guaranteed to approximately follow the central path, which ends at the optimal point for the convex optimization problem.


2. Central Path

To define the central path, first establish some notation related to the algebraic properties of the second-order cone. Let the product u∘v of two vectors u=(u0; ũ), v=(v0; {tilde over (v)}) ∈custom-character be defined as






u∘v=(uTV;u0{tilde over (v)}+v0ũ)  (11)


and the identity element for this product is denoted by the vector e=(1; 0)∈custom-character. For the Cartesian product custom-character=custom-character× . . . ×custom-character of multiple second-order cones, the vector e is defined as the concatenation of the identity element for each cone, and the circle product of two vectors is given by the concatenation of the circle product of each constituent. A consequence of this definition is the that eTe is equal to the number of cones r.


Now, for the SOCP problem of eq. (5), the central path (x(v); y(v); s(v)) is the one-dimensional set of central points, parameterized by v∈[0, ∞), which satisfies the conditions:






Ax(v)=b






A
T
y(v)+s(v)=c






x(v)∘s(v)=ve






x(v)∈custom-character,s(v)∈custom-character.  (12)


Note that the central path point (x(v); y(v); s(v)) has a duality gap that satisfies μ(x(v), s(v))=v, and that when v=0, eq. (12) recovers eq. (8).


3. Determining an Initial Point on the Central Path Via Self-Dual Embedding

Path-following primal-dual interior point methods determine the optimal point by beginning at a central point with v>0 and following the central path to a very small value of v, which is taken to be a good approximation of the optimal point. For a given SOCP, determining an initial point on the central path is non-trivial and, in general, can be just as hard as solving the SOCP itself. One solution to this problem is the homogeneous self-dual embedding, a slightly larger self-dual SOCP is formed with the properties that (i) the optimal point for the original SOCP can be determined from the optimal point for the self-dual SOCP and (ii) the self-dual SOCP has a trivial central point that can be used to initialize the IPM.


To do this, introduce new scalar variables τ, θ, and κ, which are used to give more flexibility to the constraints. Previously, Ax=b was used. In the larger program, this constraint is relaxed to read Ax=bτ−(b−Ae)θ, such that the original constraint is recovered when τ=1 and θ=0, but x=e is a trivial solution when τ=1 and θ=1. Similarly, the constraint ATy+s=c is relaxed to read ATy+s=cτ−(c−e)θ, which has the trivial solution y=0, s=e when τ=θ=1. These can be complemented with two additional linear constraints to form the program:












min

(


x
;
y
;
τ

,

θ
;
s
;
κ


)






(

r
+
1

)


θ







(
13
)














(



0



A





-
c




c
¯






-
A



0


b



-

b
¯







c





-

b





0



-

z
¯







-


c
¯








b
¯






z
¯



0



)




(



x




y




τ




θ



)




+

(



s




0




κ




0



)


=

(



0




0




0





r
+
1




)










x
,

s

𝒬





τ
,


κ

0

;





y
,

θ


free

,







where b=b−Ae, c=c−e, z=cTe+1, and r=eTe is the number of cones in the original SOCP. While eq. (13) is not exactly of the form given in eq. (5), it can still be considered a primal SOCP. Since the block matrix in eq. (13) is skew-symmetric and the objective function coefficients are equal to the right-hand-side of the equality constraints, when the dual program (c.f. eq. (6)) is computed, an equivalent program is arrived at; thus, eq. (13) is self-dual. Thus, when applying path-following primal-dual IPMs to eq. (13), in some embodiments, only the primal variables (that is x, y, τ, θ, s, K) may need to be tracked. Taking into account the addition of τ and κ, which are effectively an extra pair of primal-dual variables, the duality gap (c.f. eq. (7)) is defined as










μ

(

x
,
τ
,
s
,
κ

)

:=


1

r
+
1





(



x



s

+
κτ

)

.






(
14
)







Note that if the point (x; y; τ; θ; s; K) is feasible, i.e., if it satisfies the four linear constraints in eq. (13), then the following identity is determined:











μ

(

x
,
τ
,
s
,
κ

)

=




-

x





A



y

+


x



c

τ

-


x




c
¯


θ

+

κ

τ



r
+
1






=




-

b




y

τ

+



b
¯




y

θ

+


x



c

τ

-


x




c
¯


θ

+

κ

τ



r
+
1






=





b
¯




y

θ

-


x




c
¯


θ

+


z
¯


τ

θ



r
+
1







=
θ

,





(
15
)







where the first, second, third, and fourth rows of eq. (13) are invoked above in lines one, two, three, and four, respectively. This equality justifies the redefinition in eq. (14): noting that the primal objective function in eq. (13) is (r+1)θ, and (since the program is self-dual) the associated dual objective function is −(r+1)θ, note that the gap between primal and dual objective functions, divided by the number of conic constraints (2r+2), is exactly equal to θ.


The central path for the augmented SOCP in eq. (13) is defined by the feasibility conditions for the SOCP combined with the relaxed complementarity conditions x∘s=ve and κτ=v. Thus, the point (x=e; y=0; τ=1; θ=1; s=e; κ=1) is not only a feasible point for the SOCP in eq. (13), but also a central point with v=1.


Finally, a noteworthy property of the self-dual SOCP in eq. (13) is that the optimal point for the original SOCP in eq. (5) can be derived from the optimal point for the SOCP in eq. (13). Specifically, let (xsd*; ysd*; τ*; θ*; ssd*; κ*) be the optimal point for eq. (13) (it can be shown that θ*=0). Then if








τ
*

>
0

,


(


x
*

;

y
*

;

s
*


)

=

(



x
sd
*


τ
*


;


y
sd
*


τ
*


;


s
sd
*


τ
*



)






is an optimal primal-dual point for eqs. (5) and (6). If τ*=0, then at least one of the original primal SOCP in eq. (5) and the original dual SOCP in eq. (6) must be infeasible. As previously demonstrated, the specific SOCP for portfolio optimization in eq. (10) is primal and dual feasible, so τ*≠0 for that example.


What if there is only a point that is approximately optimal for the self-dual SOCP? An approximately optimal point for the original SOCP can still be determined. Suppose a feasible point for which μ (x, τ, s, κ)=∈. The point (x/τ; y/τ; s/τ) is custom-character(∈) close ti feasible for the original SOCP in the sense that the equality constraints are satisfied up to custom-character(∈) error













A


x
τ


-
b



=


ϵ
τ





b
-
Ae








(
16
)

















A
T



y
τ


+

s
τ

-
c



=


ϵ
τ






c
-
e



.






(
17
)







Moreover, since κ>0 and θ=∈, assert using the third row of eq. (13) that the difference in objective function achieved by the primal and dual solutions is also custom-character(∈), that is












c




x
τ


-


b




y
τ









"\[LeftBracketingBar]"




c



e

+
1



"\[RightBracketingBar]"


τ



ϵ
.






(
18
)







In summary, by using the self-dual SOCP of eq. (13), a trivial point is obtained from which to start the IPM, and given an (approximately) optimal point, the following is obtained: either an (approximately) optimal point to the original SOCP or a certificate that the original SOCP was not feasible to begin with.


4. Iterating the IPM

Each iteration of the IPM takes as input an intermediate point (x; y; τ; θ; s; κ) that is feasible (or in some formulations, nearly feasible), has duality gap







1

r
+
1




(



x



s

+

κ

τ


)





equal to μ, and is close to the central path with parameter v=μ. The output of the iteration is a new intermediate point (x+Δx; y+Δy; τ+ΔT; θ+Δθ; s+Δs; κ+Δκ) that is also feasible and close to the central path, with a reduced value of the duality gap. Thus, many iterations lead to a solution with duality gap arbitrarily close to zero.


One additional input is the step size, governed by a parameter σ<1. The IPM iteration aims to bring the next intermediate point onto the central path with parameter v=σμ. This is accomplished by taking one step using Newton's method, where the vector (Δx; Δy; Δτ; Δθ; Δs; Δκ) is uniquely determined by solving a linear system of equations called the Newton system. The first part of the Newton system is the conditions to be met for the new point to be feasible, given in the following system of N+K+2 linear equations:












(



0



A





-
c




c
¯






-
A



0


b



-

b
¯







c





-

b





0



-

z
¯







-


c
¯








b
¯






z
¯



0



)




(




Δ

x






Δ

y





Δτ




Δθ



)


+

(




Δ

s





0




Δκ




0



)


=

(






-

A




y

+

c

τ

-


c
¯


θ

-
s







A

x

-

b

τ

+


b
¯


θ









-

c




x

+


b



y

+


z
¯


θ










c
¯




x

-



b
¯




y

-


z
¯


τ





)





(
19
)







Note that if the point is already feasible, the right-hand-side is equal to zero.


The second part of the Newton system is the linearized conditions for arriving at the point on the central path with duality gap σμ. That is, aim for (x+Δx)∘(s+Δs)=σμe and (κ+Δκ)(τ+Δτ)=σμ. By ignoring second order terms (i.e., the custom-character(Δx∘Δs) and custom-character(ΔκΔτ) terms), these become






x∘Δs+s∘Δx=σμe−x∘s





κΔτ+τΔκ=σμ−κτ.  (20)


The expression above can be rewritten as a matrix equation by first defining the arrowhead matrix U for a vector u=(u0; ũ)∈Qk as









U
=


(




u
0





u
~








u
~





u
0


I




)

=


ue


+

eu


+


u
0


I

-

2


u
0


e



e


.








(
21
)







When u∈custom-character lies in the direct product of multiple second-order cones, the arrowhead matrix is custom-characterformed by placing the appropriate matrices of the above form on the block diagonal. The arrowhead matrix has the property that for any vector v, Uv=u∘v.


Using this notation, the Newton equations in eq. (20) can be written as












(



S


0


0


0


X


0




0


0


κ


0


0


τ



)




(




Δ

x






Δ

y






Δ

τ






Δ

θ






Δ

s






Δ

κ




)


=

(





σμ

e

-
Xs







σ

μ

-

κ

τ





)


,




(
22
)







where X and S are the arrowhead matrices for vectors x and s.


Equations (19) and (22) together form the Newton system. It is observered that there are 2N+K+3 constraints to match the 2N+K+3 variables in the vector (Δx; Δy; Δτ; Δθ; Δs; Δκ). As long as the duality gap is positive and (x; y; τ; θ; s; κ) is not too far from the central path (which will be the case as long as a is chosen sufficiently close to 1 in every iteration), the Newton system has a single unique solution. Note that one can choose different search directions than the one that arises from solving the Newton system presented here; this includes first applying a scaling transformation to the product of second-order cones, then forming and solving the Newton system that results, and finally applying the inverse scaling transformation. Alternate search directions are explained in section Additional Information D, but in the main text the basic search direction illustrated above is maintained, since in the numerical simulations the simple search direction gave equal or better results than more complex alternatives, and it enjoys the same theoretical guarantee of convergence.


5. Solving the Newton System

The Newton system formed by combining eqs. (19) and (22) is an L×L linear system of the form Gu=h, where L=2N+K+3. Classically this can be solved exactly a number of ways, the most straightforward being Gaussian elimination, which scales as custom-character(L3). Using Strassen-like tricks, this can be asymptotically accelerated to custom-character(Lω) where ω<2.38, although practically the runtime is closer to custom-character(L3). Meanwhile, the linear system can be approximately solved using a variety of iterative solvers, such as conjugate gradient descent or the randomized Kaczmarz method. The complexity of these approaches depends on the condition number of the Newton matrix. Section IV discusses quantum approaches to solving the Newton system.


It is noteworthy to distinguish methods that exactly solve the Newton system, and methods that solve it inexactly, because inexact solutions typically lead to infeasible intermediate points. As presented above, the Newton system in eqs. (19) and (22) can tolerate infeasible intermediate points; the main consequence is that the right-hand-side of eq. (19) becomes non-zero. As discussed in section IV, exact feasibility is difficult to maintain in quantum IPMs, since the Newton system cannot be solved exactly.


The inexact-feasible IPM(IF-IPM) is a workaround by which exact feasibility can be maintained despite an inexact linear system solver. For the IF-IPM, this disclosure assumes access to a basis for the null space of the feasibility constraint equations, that is, a linearly independent set of solutions to eq. (19) when the right-hand-side is zero. These basis vectors are arranged as the columns of a matrix B; since there are N+K+2 linear feasibility constraints and 2N+K+3 variables, the matrix B should have N+1 columns. In the case of portfolio optimization, a matrix B satisfying this criterion can be deduced by inspection, as discussed in section Additional Information C; however, this choice does not yield a B with orthogonal columns. Generating a B with orthonormal columns can be done by performing a QR decomposition of the matrix in eq. (19), which would incur a large one-time classical cost of custom-character((N+K)3) operations. Better asymptotic scaling for QR decomposition can be accomplished using fast matrix multiplication. In either case, since B is a basis for the null space of the constraint equations, there is a one-to-one correspondence between vectors Δz∈custom-character, and vectors that satisfy eq. (19) via the relation (Δx; Δy; Δτ; Δθ; Δs; Δκ)=BΔz. Thus, the Newton system can be reduced to











[


(



S


0


0


0


X


0




0


0


κ


0


0


τ



)



B

]



Δ

z

=

(





σ

μ

e

-
Xs







σ

μ

-

κ

τ





)





(
23
)













(


Δ

x

;

Δ

y

;

Δ

τ

;

Δ

θ

;

Δ

s

;

Δ

κ


)

=

B

Δ


z
.






(
24
)







The Newton system above can be solved by first computing Δz by inverting the quantity in brackets in the first line and applying it to the right-hand-side, and then computing (Δx; Δy; Δτ; Δθ; Δs; Δκ) by performing the multiplication BΔz. This matrix-vector product can be accomplished classically in custom-character(N2) operations. Note that matrix-matrix products where one of the matrices is an arrowhead matrix (S or X) can also be carried out in custom-character(N2) classical time, as the form of arrowhead matrices given in eq. (21) implies that the product can be computed by summing several matrix-vector products. Finally, note that since the second and fourth block columns of the first matrix in eq. (22) are zero, the second and fourth block rows of B (e.g., in eq. (C1)) can be completely omitted from the calculation.


Thus, there are three main choices for how to run the IPM when the solution to linear systems is inexact: first, by solving eqs. (19) and (22) directly and allowing intermediate solutions to be infeasible; second, by determining a matrix B by inspection as described in section Additional Information C and then solving eqs. (23) and (24); third, by determining a matrix B via QR decomposition and then solving eqs. (23) and (24). When the linear system is solved using a quantum algorithm, as discussed in section IV, this disclosure refers to the algorithm that results from each of these three options by II-QIPM, IF-QIPM, and IF-QIPM-QR, respectively. The pros and cons of each method are summarized in table II.


6. Neighborhood of the Central Path and Polynomial Convergence

Prior literature establishes that if sufficiently small steps are taken (i.e., if σ is sufficiently close to 1), then each intermediate point stays within a small neighborhood of the central path. This disclosure now reviews these conclusions. For a vector u=(u0; ũ)∈custom-character, the following matrix is defined:











T
u

=

(





u
0






u
~











u
~












u
0
2

-




u
~



2




I

+



u
~




u
~






u
0

+



u
0
2

-




u
~



2










)


,




(
25
)







which, as for the arrowhead matrix, generalizes to the product of multiple cones by forming a block diagonal of matrices of the above form. This disclosure uses the following distance metric






d
F(x,τ,s,κ)=√{square root over (2)}√{square root over (∥Txs−μ(x,τ,s,κ)e∥2+(τκ−μ(x,τ,s,κ))2)}.  (26)


The distance metric induces a neighborhood custom-character, which includes both feasible and infeasible points, as well as the neighborhood custom-characterF, which includes only feasible points






custom-character(γ)={(x;y;τ;θ;s;κ): dF(x,τ,s,κ)≤γμ(x,τ,s,κ)}  (27)






custom-character
F(γ)=custom-character(γ)∩custom-characterF,  (28)


where custom-characterF denotes the set of feasible points for the self-dual SOCP. Note that the vector Txs can be computed classically in custom-character(N) time given access to the entries of x and s. Thus, whether or not a point lies in custom-character(γ) can be determined in custom-character(N) time.


So long as 0≤γ≤⅓ and (x; y; τ; θ; s; κ)∈custom-characterF(γ), then the following may be true:





(x+Δx;y+Δy;τ+Δτ;θ+Δθ;s+Δs;κ+Δκ)∈custom-characterF(Γ),  (29)


where










Γ
=


4


(


γ
2

+

2


(

r
+
1

)




(

1
-
σ

)

2



)





(

1
-

3

γ


)

2


σ



.




(
30
)














TABLE II







Choices on which version of the Newton system to solve lead to different


versions of the QIPM, even with the same underlying quantum subroutines.











II-QIPM
IF-QIPM
IF-QIPM-QR














Newton system
Equations (19) and (22)
Equations (23) and (24)
Equations (23) and (24)


Size of Newton system (L)
2N + K + 3
N + 1
N + 1


Feasible intermediate points
No
Yes
Yes


Caveats
Theoretical convergence
Ill-conditioned null-space
Uses classical QR



guarantee uses custom-character  (r2)
basis leads to large
decomposition, which could



(rather than custom-character  ((√{square root over (r)}))
condition number of
dominate overall runtime



iterations
Newton system









Thus, if Γ≤γ, and assuming the Newton system is solved exactly, every intermediate point will lie in custom-characterF(γ). This condition is met, for example, if γ= 1/10 and σ=1−(20√{square root over (2)}√{square root over ((r+1))})−1. Since each iteration reduces the duality gap by a factor σ, the duality gap can be reduced to ∈ after roughly only 20√{square root over (2(r+1))} ln(1/∈) iterations. If the Newton system is solved inexactly, but such that feasibility is preserved (e.g., by solving inexactly for Δz and then multiplying by B, as described above), then an error δ on the vector (x; τ; s; κ) can be tolerated, and the resulting vector can still be within the neighborhood at each iteration.


On the other hand, if the Newton system is not solved exactly, then the resulting vector may not be feasible. Thus, the II-QIPM version of the QIPM does not enjoy the theoretical guarantee of convergence in custom-character(√{square root over (r)}) iterations that the IF-QIPM and IF-QIPM-QR versions do (see table II). The best guarantees for the II-QIPM would imply convergence only after custom-character(r2) iterations. Nevertheless, it is unclear if a small amount of infeasibility makes a substantial difference in practice: multiple versions of the QIPM were simulated and similar overall performance was observed when intermediate solutions were allowed to be infeasible, despite an inferior theoretical guarantee of success. Thus, in sections V and VI, where the QIPM implementation, resource count, and numerical analysis are described, this disclosure focuses on the II-QIPM. This disclosure presents some of the results of the numerical simulations of the IF-QIPM and IF-QIPM-QR results in the section Additional Information.


IV. QUANTUM INTERIOR POINT METHODS (QIPM)
A. Introduction to QIPM

As discussed in section III, each iteration of an IPM SOCP solver involves forming and solving a linear system of equations that depends on the intermediate point at the current iteration. For classical IPM implementations for SOCP, the linear systems of equations are typically solved exactly; for example, the numerical SOCP solving package ECOS solves linear systems with a sparse LDL (Cholesky) factorization. For arbitrary dense systems, the runtime of solving an L×L system this way is custom-character(L3), but by exploiting sparsity the actual runtime in practice could be much faster, by an amount that is hard to assess. Alternatively, it would, in principle, be possible to employ classical iterative approximate linear system solvers such as conjugate gradient descent or the randomized Kaczmarz method. The choice of the linear system solver thereby determines the overall complexity of the IPM SOCP solver. An idea of QIPM is to use a quantum subroutine to solve the linear system of equations. Other steps of QIPMs may be classical and may remain the same as described in section III. As a quantum linear system solver (QLSS) does not solve the exact same mathematical problem as classical linear system solvers and, moreover, a QLSS uses coherent (quantum) access to the classical data as given by the entries of the relevant matrices, there are various additional tools (discussed herein) that allow embedded QLSS subroutines as a step of IPM SOCP solvers.


First, this disclosure discusses in section IV B the input and output model of QLSSs and present the complexity of state-of-the-art QLSSs. Then, section IV C provides constructions based on quantum random access memory (QRAM) to load classical data as input into a QLSS and discusses the complexity overhead arising from that step. Subsequently, section IV D presents so-called pure state quantum tomography that allows to convert the output of the QLSS into an estimate of the classical solution vector of the linear system of equations. Section IV E puts all the steps together and states the overall classical and quantum complexities of using QLSSs as a subroutine in IPM SOCP solvers. The idea is to compare these costs to the complexities of classical IPM SOCP solvers and point out regimes where quantum methods can potentially scale better that any purely classical methods (e.g., in terms of the SOCP size N, the matrix condition number κ, etc.)


B. Quantum Linear System Solvers

For current purposes, a linear system of equations is given by a real invertible L×L matrix G together with a real vector h=(h1, . . . , hL), and one is looking to give an estimate of the unknown solution vector u=(u1, . . . , uL) defined by Gu=h. The (Frobenius) condition number is defined as





κF(G):=∥G∥F∥G−1∥,  (31)


where ∥⋅∥F denotes the Frobenius norm and ∥⋅∥ for a matrix argument denotes the spectral norm.


For this setting, the input to a QLSS is then comprised of: (i) a preparation unitary Uh that creates the custom-character:=┌log L┐ qubit quantum state





|h>:=∥h∥−1·Σi=1Lhi|icustom-character via|hcustom-character=Uh|custom-character,  (32)


where ∥⋅∥ for a vector argument denotes the vector two-norm (standard Euclidean norm), (ii) a block encoding unitary UG in the form










U
G

:=

(




G



G


F




·




·


·



)





(
33
)







on custom-character+custom-characterG qubits for some custom-characterG custom-character, and (iii) an approximation parameter εQLSP ∈(0,1]. The quantum linear system problem (QLSP) is stated as follows: For a triple (G, h, εQLSP) as above, the goal is to create an custom-character-qubit quantum state |{tilde over (v)}custom-character such that


















v
~



-


ν







ε
QLSP







for

|
ν


:=







i
=
1




L




u
i


i











i
=
1




L




u
i


i







,







(
32
)







defined by Gu=h with u=(u1, . . . , uL), by employing as few times as possible the unitary operators UG, Uh, their inverses UG, Ut, controlled versions of UG, Uh, and additional quantum gates on potentially additional ancilla qubits. The state-of-the-art QLSS using the fewest calls to UG, Uh and their variants, is based on ideas from discrete adiabatic evolution. This disclosure notes the following explicit complexities. In this formulation, the quantum state |vcustom-character corresponds to the normalized solution vector of the normalized linear system Gu=h. Thus, the state |vcustom-character does not carry information on the norm of the solution ∥u∥. This norm is related to v by the relationship ∥u∥=∥h∥/∥Gv∥.


Proposition 1. The QLSP for (G, h, ε1) can be solved with a quantum algorithm on ┌log2(L)┐+4 qubits for










ε
1




C
·



κ
F

(
G
)

Q


+

𝒪



(




κ
F

(
G
)


Q

)







(
35
)







for some constant C≤15307 using Q≥κF(G) controlled queries to each of UG and UG, and 2Q queries to each of Uh and Uh, and constant quantum gate overhead. If G is positive semi-definite, then C≤5632 instead.


Note that a stronger version of above proposition works with the (regular) condition number κ(G):=∥G∥∥G−1∥, but it uses a block-encoding of the form eq. (33) in which the normalization factor is ∥G∥ rather than ∥G∥F. In the current case, the Frobenius version κF(G) is used, since there may not a straightforward method to perform UG with normalization factor ∥G∥F, described in section IV C. It is then sufficient to give upper bounds for the remaining κF(G) to run the algorithm from proposition 1. In practice, such upper bounds are given by using appropriate heuristics (cf. section V on implementations).


Note that proposition 1 implies a solution to the QLSP in eq. (34) with an asymptotic query complexity of custom-characterFQLSP) to UG, Uh and their variants and under standard complexity-theoretic assumptions this is optimal in terms of the scaling custom-character(κ), but not in terms of the scaling custom-characterQLSP). To get to an improved custom-character(log(1/εQLSP)) scaling, an eigenstate filtering method may be used that additionally invokes a quantum singular value transform based on a minimax polynomial. The following overall complexities are provided.


Proposition 2. The QLSP problem for (G, h, ε2) can be solved with a quantum algorithm on ┌log2(L)┐+5 qubits that produces a quantum state





√{square root over (p)}|05custom-character|{tilde over (v)}custom-character+√{square root over (1−p)}|⊥custom-character|failcustom-character  (36)


with custom-character05|⊥custom-character|=0 and success probability p≥½. With that, the sought-after ε2-approximate solution quantum state |{tilde over (v)}custom-character can be prepared using Q+d controlled queries to each of UG and UG, and 2Q+2d queries to each of Uh and Uh, where






Q=2F(G)+custom-character(√{square root over (κF(G))})  (37)






d=F(G)ln(2/ε2).  (38)


Here, C≤15307 is the same constant as in proposition 1.


This version of the algorithm basically uses proposition 1 with constant choice of ε1≤¼, and then uses eigenstate filtering to measure whether the final state is the correct solution state. On average the algorithm is repeated no more than twice to produce the desired state |{tilde over (v)}custom-character. The resulting scaling that proposition 2 implies for the QLSP problem in eq. (34) is custom-character(κ log(1/εQLSP)), which under standard complexity-theoretic assumptions is optimal in both κ and εQLSP. In practice the Q=2CκF(G) dominates over d and all other terms can be safely neglected for typical settings—even for finite scale analyses. Moreover, the constant C is typically an order of magnitude smaller than the estimates given; for positive semi-definite G the constant is estimated as 638. No direct estimates for general matrices G are available, but this disclosure henceforth assumes C=2000 for the numerical estimates. Additionally, note that for the eigenstate filtering step via QSVT, the minimax polynomial and its corresponding quantum signal processing angles have to be computed. This is done as part of classical pre-processing.


Note that the implementation of the QLSS in each of proposition 1 and proposition 2 assume perfect implementation of the underlying circuits, without additional gate synthesis errors. In practice, however, these circuits will not be implemented perfectly, and hence additional sources of error are later included (e.g., block-encoding error, imperfect rotation gates, etc.) that also contribute to εQLSP. These additional contributions are in section IV D, for example.


The following continues by laying out the additional classical and quantum resources used to employ QLSS for estimating in an end-to-end fashion the classical solution vector v=(v1, . . . , v1) instead of the quantum state |vcustom-character.


C. Block-Encoding Via Quantum Random Access Memory (QRAM)

Many quantum algorithms (and in particular for the current use case), use coherent access to classical data for use in the algorithm. Block-encodings of matrices provide a commonly used access model for the classical data by encoding matrices into unitary operators, thereby providing oracular access to the data. As mentioned above, for a matrix G∈custom-character, a unitary matrix UG block-encodes G when the top-left block of UG is proportional to G, i.e.











U
G

:=

(




G
/
α



·




·


·



)


,




(
39
)







where α≥∥G∥ is a normalization constant, chosen as α=∥G∥F for the use case. The other blocks in UG are irrelevant, but they are encoded such that UG is unitary. For current real matrices G are focused on, but the extension to complex matrices is straightforward. A block-encoding makes use of unitaries that implement (controlled) state preparation, as well as quantum random access memory (QRAM) data structures for loading the classical data. Specifically, QRAM is referred to as the quantum circuit that allows query access to classical data in superposition:



















j



ψ
j





"\[LeftBracketingBar]"

j









"\[LeftBracketingBar]"

0






QRAM




j



ψ
j





"\[LeftBracketingBar]"

j










"\[LeftBracketingBar]"


a
j





,




(
40
)







where j is the address in superposition with amplitude ψj and |ajcustom-character is the classical data loaded into a quantum state. There are several models of QRAM one can use that differ in the way in which the data is loaded. The two most notable QRAM models are the select-swap (SS) model, which is particularly efficient in terms of T-gate utilization, and the bucket-brigade (BB) model, which has reduced susceptibility to errors when operated on potentially faulty hardware.


The block-encoding unitary UG acts on custom-character+custom-characterG qubits, where custom-character=┌log2(L)┐ and, in our construction, custom-characterG=custom-character. To build it, UG may be formed as the product of a pair of controlled-state preparation unitaries UL and UR. Specifically,






U
G
=U
R

U
L,  (41)






U
R:|0>⊗l|j>custom-characterjcustom-character|jcustom-character  (42)






U
L:|0>⊗l|k>custom-character|kcustom-characterkcustom-character  (43)


where the custom-character-qubit states |ψjcustom-character and |ϕkcustom-character are determined from the matrix elements Gjk of G, as follows:














"\[LeftBracketingBar]"


ψ
j




=



k




G

j

k





G

j
,
·









"\[LeftBracketingBar]"

k









(
44
)

















"\[LeftBracketingBar]"


ψ
k




=



j





G

j
,
·







G


F




,




(
45
)







where Gj, denotes the jth row of G. That is, controlled on the second custom-character-qubit register in the state |jcustom-character, UR prepares the custom-character-qubit state |ψjcustom-character into the first custom-character-qubit register, and UL performs the same operation for the states |ϕkcustom-character modulo a swap of the two registers. Both UL and UR utilize an additional custom-character QRAM ancilla qubits that begin and end in the state |0custom-character. These controlled-state preparation unitaries UR and UL are implemented by combining a QRAM-like data-loading step with a protocol for state preparation of custom-character-qubit states. There are several combinations of state preparation procedure and QRAM model one can choose with varying benefits and resource requirements. Reference arXiv:2206.03505 (hereafter “Clader”) studies the resources used to implement these block-encodings and provides explicit circuits for their implementation. This disclosure simply imports the relevant resource estimates from that work in table III. In the current setting, the matrices to block encode are typically dense, which is why the general constructions from Clader are sufficient. For the current purposes, this disclosure works with the minimum depth circuits that achieve a T-gate depth of custom-character(log L), at the price of using a total number of custom-character(L2) many qubits for the data structure implementing the block encoding unitary UG. Additionally, the custom-character-qubit unitary Uh defined by |hcustom-character=Uh|custom-character corresponds to the special case of quantum state preparation and is directly treated by the methods outlined in Clader. The resources used to synthesize Uh up to error εh are also reported in table III.









TABLE III







Logical quantum resources used to block-encode (left column)


and control-block-encode (right column) an L × L matrix G to


precision εG ∈ [0, 1], where L = custom-character  is


assumed. Here terms are suppressed doubly and triply logarithmic


in L and 1/εG (see Clader).











Controlled Block


Resource
Block Encoding
Encoding





# of qubits
NQbe: =4L2 − 3L + 2 custom-character  − 1
NQche: =NQbe + L


T-depth
TDbe: =10 custom-character  + 24 log2(1/εG) + 44
TDcbe: =TDbe + 4


T-count
TCbe: =(12 log2(1/εG) + 56)L2
TCcbe: =TCbe +



24L − 12 log2(1/εG) − 32 custom-character  − 32
16(L − 1)
















TABLE IV







Logical quantum resources used to prepare an arbitrary custom-character  -qubit quantum


state |h custom-character  from classical data (left column) and a single-qubit


controlled version (right column) to precision εh ∈ [0, 1]. Here


terms are suppressed doubly and triply logarithmic in L and 1/εh (see


Clader). For a single-qubit control, there are no additional Clifford gates


used, which can be observed by examining the state-preparation procedure


in Clader and noting that the state [0 custom-character  | custom-character  + |1 custom-character  |ψ custom-character  can


be prepared with minor modifications to the procedure that prepares |ψ custom-character  .


First, use the “flag” qubits to control both the angle loading and unloading


steps (rather than just the unloading steps), and second, control every flip


of the flag qubits in that procedure with the first single-qubit control, thus


turning NOT gates into CNOT gates, which are also Clifford. When the


control is ON, the procedure works as before, and when the control is


OFF, none of the qubits leave the |0 custom-character  state.











Controlled State


Resource
State Preparation
Preparation





# of qubits
NQsp: =4L + custom-character  − 6
NQcsp: =NQsp + 1


T-depth
TDsp: =3 custom-character  + 12 log2(1/εh) + 24
TDcsp: =TDsp


T-count
TCsp: =(12 log2(1/εh) + 40)L −
TCcsp: =TCsp



12 log2(1/εh) − 16 custom-character  − 40









The minimum-depth block encodings of Clader also incur some classical costs. Specifically, the quoted depth values are only achievable assuming a number of angles have been classically pre-computed and for each angle a gate sequence of single-qubit Clifford and T gates that synthesizes a single-qubit rotation by that angle up to small error. Calculating one of the angles can be done by summing a subset of the entries of G and computing an arcsin. Meanwhile, circuit synthesis uses applying a version of the Solovay-Kitaev algorithm. For the block-encoding procedure, L(L−1) angles and their corresponding gate sequences are computed, which uses a total runtime of L2 poly log(1/εG), although this computation is amenable to parallelization. For the state preparation procedure, L−1 angles and their sequences are used.


D. Quantum State Tomography

This disclosure described how a quantum state |{tilde over (v)}custom-character approximating the (real-valued) solution |vcustom-character of a linear system up to precision εQLSP can be produced. As mentioned in section IV B, in the actual circuit implementation, the approximation error εQLSP accounts for both the inherent error from eigenstate filtering captured in proposition 2 as well as additional gate synthesis error arising from imperfect implementation of block-encoding unitaries and single-qubit rotations. The next step is to approximately read out the amplitudes of |{tilde over (v)}custom-character into classical form. To start out, this disclosure proves the following proposition, which communicates how many copies of a quantum state are used to provide a good enough classical description of it, up to a phase on each amplitude.


Proposition 3. Let 0<ε,δ<1 and |ψcustom-characterj∈[L]αj|jcustom-character be a quantum state. Then,







5
+

21



3


ε
2






ln(2L/δ)<3.1942ε−2 ln(2L/δ) measurements of |ψcustom-character in the computational basis suffice to learn an εcustom-character-norm estimate |{tilde over (α)}| of |α|, with success probability at least 1−δ.


The proof is provided in the section Additional Information B1. Recall that proposition 2 gives a unitary U such that






U|05custom-character=√{square root over (p)}|05custom-character{tilde over (v)}custom-character+√{square root over (1−p)}|⊥custom-character|failcustom-character  (46)


with |{tilde over (v)}custom-character:=Σi=1N{tilde over (v)}i|icustom-character, <05|⊥custom-character=0, and p≥½. The vector {tilde over (v)} may have complex coefficients, but it approximates a real vector v up to some error εQLSP in custom-character2 norm. A goal is to obtain an estimate {tilde over (v)}′=(v1′, . . . , vN′) such that





v−{tilde over (v)}′∥≤ξ for an error parameter ξ∈[0,1].  (47)


where ξ captures other (e.g., all) sources of error. Proposition 3 is not quite sufficient because it only gives us an estimate of the absolute value of V. However, the following procedure is sufficient:

    • 1. Create k=57.5 L ln(δL/δ)/(ε2(1−ε2/4)) many copies of the quantum state Ucustom-character=√{square root over (p)}|05custom-character|{tilde over (v)}custom-character+√{square root over (1−p)}|⊥custom-character|failcustom-character, and measure them all in the computational basis to give empirical estimates {pi}i=1L of the probabilities p|{tilde over (v)}i|2.
    • 2. Using controlled applications of U, create k=57.5 L ln(6L/δ)/(ε2(1−ε2/4)) copies of


























2


-
1

/
2






"\[LeftBracketingBar]"


0
5









"\[LeftBracketingBar]"

0






p





"\[LeftBracketingBar]"


v
~





+


2


-
1

/
2






"\[LeftBracketingBar]"


0
5










"\[LeftBracketingBar]"

1









i
=
1

L




p
i







"\[LeftBracketingBar]"

i






+



"\[LeftBracketingBar]"













"\[LeftBracketingBar]"


fail






,




(
48
)







which by applying a Hadamard can be mapped to

























"\[LeftBracketingBar]"


0
5








"\[LeftBracketingBar]"

0













p





"\[LeftBracketingBar]"


v
~





+









Σ



i
=
1

L




p
i







"\[LeftBracketingBar]"

i







2


+



"\[LeftBracketingBar]"


0
5









"\[LeftBracketingBar]"

1













p





"\[LeftBracketingBar]"


v
~





-









Σ



i
=
1

L




p
i







"\[LeftBracketingBar]"

i







2


+



"\[LeftBracketingBar]"













"\[LeftBracketingBar]"


fail






.




(
49
)







Here |⊥′custom-character is an arbitrary state orthogonal to |05custom-characterand |fail′custom-character and |fail″custom-character are arbitrary unnormalized states. The quantities √{square root over (pi′)} are (possibly complex) amplitudes that satisfy |√{square root over (pi′)}−√{square root over (pi)}|εtsp for all i; they arise because the state Σi=1L√{square root over (pi′)}|icustom-character can only be prepared up to some error. Next, measure this state in the computational basis, denoting the measurement count of the result 06i as ki+ and the result 05 1i as ki.

    • 3. Define










a
i
+

=

min

(



p
i


,



k
i
+

-

k
i
-




p
i




)





(
50
)













a
i
-

=

max

(


-


p
i



,



k
i
+

-

k
i
-




p
i




)





(
51
)













and


let




a
~

i


=

{




0




if




p
i







2

3



2

L





ε



1
-


ε
2

4




+

ε

t

s

p









a
i
+







if




a
~

i




0


and



k
i
+




k
i
-









a
i
-







if




a
~

i




0


and



k
i
+


<

k
i
-





.






(
52
)







Output the estimate












"\[LeftBracketingBar]"



v
~






=



Σ



i
=
1

L




a
~

i





"\[LeftBracketingBar]"

i





/









i
=
1

L




a
~

i
2



.





Proposition 4. Suppose that ∥{tilde over (v)}−v∥≤εQLSP and that v is a real-valued vector. Let ε and εtsp be constants that satisfy ε+√{square root over (2L)}εtsp+√{square root over (2)}εQLSP≤½. Then the algorithm above outputs an estimate {tilde over (v)}′ such that ∥{tilde over (v)}′−v∥<ε+1.58√{square root over (L)}εtsp+1.58εQLSP with probability 1−δ.


The proof is provided in the section Additional Information B1. The statement is used to bound the total error parameter ξ by the quantity ε+1.58√{square root over (L)}εtsp+1.58εQLSP. Proposition 4, together with proposition 2, produces with high probability an custom-character(ε) good estimate {tilde over (v)}′ of v by using custom-character(Lln(L)/ε2) many samples. If a goal is to resolve the initial linear system Gu=h, then the vector {tilde over (v)}′ produced as in Section IV D as an estimate for the normalized vector v=u/∥u∥, gives an estimate for u via








u
~

:=



v
~



·



h





G



v
~









,




for which the following is found:









u
-

u
~









v
-


v
~






·

(

1
+

κ

(
G
)


)

·




h





G



v
~







.






There are other methods in the literature that allow to perform pure state quantum tomography with comparable query complexities, but this disclosure favors the above method because of its computational simplicity, and the fact that it does not require solving any potentially costly additional optimization problems. The sample complexity has been improved to custom-character(Lln(L)/ε2), which comes at the cost of more complicated quantum circuits and higher constant overheads (See Reference arXiv:2206.03505). It would be interesting to work out the more involved finite complexity of this result, and further comment on the potential impact of this are provided in section VII.


E. Asymptotic Quantum Complexity

Putting things together, the steps of our QLSS for given real L×L matrix G and real vector h of size L may be:

    • 1. Construct the circuits that implement the block-encoding unitaries UG and Uh up to error εG and εh via quantum state preparation and QRAM, which involves a classical pre-processing cost scaling as L2poly log(1/εG,h). The quantum resources used are described in table III. The T-gate depth (referred to as “time complexity”) is custom-character(log L) and the total T-gate count is custom-character(L2).
    • 2. Employ the QLSS unitary from proposition 2 to approximately solve the corresponding QLSP, leading to the quantum state |{tilde over (v)}custom-character. The query complexity to UG, Uh, their controlled versions, and their inverses, is custom-characterF(G) log(1/ε)). The number of qubits useed is ┌log L┐+5.
    • 3. Repeat the previous step custom-character(Lln(L/δ)ε−2) many times to implement the pure state quantum tomography scheme from section IV D, which also includes the use of an custom-character(L) qubit QRAM structure, and one ancilla qubit. Tomography leads to the sought-after classical vector estimate {tilde over (v)}′ with ∥{tilde over (v)}′−∥≤ε.


The QLSS can then be used for each iteration of an IPM SOCP solver, which involves forming and solving a linear system of equations, resulting in the QIPM SOCP solver. This disclosure provides the quantum circuits used to implement the solver in the section IV D.


F. Quantum Circuits

The following are the quantum circuits used for the QLSS of proposition 1. The QLSS includes applying a unitary U[s] for many different values of s, where U[s] is a block-encoding of a certain Hamiltonian related to G and h, as specified below. The unitary acts on 4+custom-character+custom-characterG total qubits, where the final custom-characterG qubits are ancillas associated with UG. The four single-qubit registers are referred to with labels a1, a2, a3, a4, the custom-character-qubit register with label L, and the custom-characterG-qubit register with label custom-characterG. These labels are used as subscripts on bras, kets, and operators to clarify the register to which they apply. The circuit for U[s] is depicted in FIG. 1. Specifically, the unitary U[s] is a block-encoding of the (2+custom-character)-qubit Hamiltonian c(s)·custom-character[s]:=(1−ƒ(s))custom-character0+ƒ(s)custom-character1 on registers a4a1L, where c(s) is a normalization factor (defined later in eq. (60)),











0

:=

(



0


0








I
L

-



"\[LeftBracketingBar]"

h







h




"\[RightBracketingBar]"


L



0




0


0


0



-

I
L












I
L

-



"\[LeftBracketingBar]"

h







h




"\[RightBracketingBar]"


L



0


0


0




0



-

I
L




0


0



)





(
53
)














and




1


:=

(



0


0


0


G




0


0









G


(


I
L

-



"\[LeftBracketingBar]"

h








h





"\[RightBracketingBar]"



L

)



0




0









(


I
L

-



"\[LeftBracketingBar]"

h








h





"\[RightBracketingBar]"



L

)


G



0


0





G




0


0


0



)


,




(
54
)







and where IL denotes the identity operation on subsystem L, and the four rows and columns correspond to the sectors with qubits a4, a1 set to (0,0), (0,1), (1,0), (1,1). FIG. 1 features the expressions:





















C



R
0

(
s
)


:=



"\[LeftBracketingBar]"

0







0




"\[RightBracketingBar]"



a
4





R

(
s
)


a
2



+



"\[LeftBracketingBar]"

1







1





"\[RightBracketingBar]"




a
4




H

a
2






(
55
)

























CR
1

(
s
)

:=



"\[LeftBracketingBar]"

1







1





"\[RightBracketingBar]"




a
4





R

(
s
)


a
2



+



"\[LeftBracketingBar]"

0







0





"\[RightBracketingBar]"




a
4




H

a
2






(
56
)

























V
G

:=



"\[LeftBracketingBar]"

0







0





"\[RightBracketingBar]"




a
2




Z

a
1




l

L



G




+



"\[LeftBracketingBar]"

1







1





"\[RightBracketingBar]"




a
2





(



0



U
G






U
G




0



)



a
1


L



G




,




(
57
)







where H denotes the single-qubit Hadamard gate, and R(s) is given by










R

(
s
)

:=


1




(

1
-

f

(
s
)


)

2

+


f

(
s
)

2






(




1
-

f

(
s
)





f

(
s
)






f

(
s
)




-

(

1
-

f

(
s
)


)





)






(
58
)













f

(
s
)

:=




κ
F

(
G
)




κ
F

(
G
)

-
1


·

(

1
-


(

1
+

s

(




κ
F

(
G
)


-
1

)


)


-
2



)






(
59
)







The normalization factor of R(s) above combines with a factor of 1/√{square root over (2)} introduced by the Hadamard gate to give an overall normalization factor for custom-character(s) of






c(s)=(2((1−f(s))2+f(s)2))−1/2∈[2−1/2,1]  (60)


and scheduling function ƒ(s) with ƒ(0)=0 and ƒ(1)=1. Note the self-inverse property U[s]2=1 ∀s ∈[0,1]. The overall quantum circuit U for the quantum algorithm of proposition 1 is then given as:









U
:=





=
1

Q


P
[

1
-

j
/
Q


]






(
61
)







with the walk operator






P[s]:=WU[s],


where W is the operator that acts as identity on registers a4a1L (which host the Hamiltonian custom-character[s]) while performing the reflection (2|0custom-charactercustom-character0custom-charactercustom-character) on the remaining qubits. The unitary U makes Q controlled queries to each of UG and UG, and 2Q queries to each of Uh and Uh, and it has constant quantum gate overhead.



FIG. 1 is a diagram of an example quantum circuit that is a main component of the example quantum circuit for proposition 1, enacting the unitary U[s] on registers a3a4a2a1Lcustom-characterG of the scaled Hamiltonian c(s)·custom-character[s], where custom-character[s]=(1−ƒ(s))custom-character0+ƒ(s)custom-character1, on registers a4a1L. The quantum gates and functions are defined in eqs. (53) to (59) except for sub-circuit UQh, which is depicted in FIG. 4. The unitary U[s] is then used in eq. (61) to define the overall quantum circuit U for proposition 1.


Next, give the remaining QSVT eigenstate filtering quantum circuit for the refined quantum linear system solver of proposition 2. The null space of c(1)·custom-character[1] is of interest, which has ground-state energy equal to zero and spectral gap at least c(1)κF−1(G)=(√{square root over (2)}κF)−1. As such, employ the Chebyshev minimax polynomial:












R
l

(

x
,


κ
F

-
1


(
G
)


)

:=



T
l

(


-
1

+

2




x
2

-



κ
F

-
2


(
G
)

/
2



1
-



κ
F

-
2


(
G
)

/
2





)



T
l

(


-
1

+

2




-


κ
F

-
2


(
G
)


/
2


1
-



κ
F

-
2


(
G
)

/
2





)



,




(
62
)







where Tl(⋅) is l-th Chebyshev polynomial of the first kind, as part of the corresponding QSVT quantum circuit. Rl has even degree d equal to






d:=2l=2┌κF(G)ln(2/εqsp))for some εqsp∈(0,1]  (63)


where εqsp is the precision to which Rl approximates the optimal filter operator. The QSP subscript stands for “quantum signal processing.”


The circuit for the eigenstate filtering step is depicted in FIG. 2. To implement it, one may classically pre-compute the corresponding QSP angles {ϕ1, . . . , ϕd}. The query complexity to the block encoding U[1] is given by d, the additional gate overhead is as in FIG. 2, and the total number of qubits is 1+4+custom-character. Finally, using the overall quantum circuit U from proposition 1 with constant approximation parameter ε1=¼ therein (to produce an input state to the quantum circuit of FIG. 2), gives the overall quantum circuit of the QLSS from proposition 2, which then solves the QLSP to error ε2qsp.



FIG. 2 is a diagram of an example Quantum singular value transform (QSVT) circuit, acting on the block-encoding U[1] of custom-character(1)=custom-character1/√{square root over (2)}, as defined in eq. (54). The circuit features one additional ancilla qubit and depends on the classically precomputed rotation angles {ϕ1, . . . , ϕd}.


A quantum tomography routine may also include performing controlled versions of the above circuits as described in eq. (49) and illustrated in FIG. 3 (which replaces FIG. 1). More specifically, FIG. 3 is a diagram of an example-controlled version of the quantum circuit in FIG. 1, controlled on qubit c. Note that not all gates need to be controlled on c, as their inverses follows in the circuit. The controlled circuits can be accomplished by modifications to the circuits in FIGS. 1 and 2 as follows.


Any QSVT circuit can be made controlled by simply controlling the application of the z rotation gates, since the rest of the circuit contains only symmetric applications of unitary gates and their inverses. Thus, a controlled version of FIG. 2 may be created by simply performing controlled-σz rotations, which uses two CNOT gates and an extra single qubit σz rotation gate.


Controlling the linear system portion is not enough to implement eq. (49). This may (e.g., must) be followed up with a controlled state-preparation routine, controlled on the value of the qubit c being in the |1custom-character state. The resource analysis for controlled state-preparation is reported in Ref. Clader. The resource counts are reported here in table IV.


V. IPM IMPLEMENTATION AND RESOURCE ESTIMATES FOR PO

The previous section reviewed the ingredients used to implement the QIPM, namely, QLSS, block-encoding, and tomography. Here, combine those ingredients to describe how the QIPM is actually implemented, making several observations that go beyond prior literature. Also perform a full resource analysis of the entire protocol and report resources used to run the algorithm.


A. QIPM Loop and Pseudo-Code

A QIPM is formed from an IPM by performing the step of solving a linear system with a quantum algorithm; the rest of the steps are classical. Example Algorithm 1 presents pseudocode for the interior point method where the single quantum subroutine—approximately solving a linear system—appears in blue text. The input to Algorithm 1 is an SOCP instance with N variables, K linear constraints, and r second-order cone constraints, along with a tolerance parameter ∈. Here note that K=custom-character(N) in the case of the formulation of the PO problem simulated in section VI. The output of the QIPM is a vector x that is custom-character(∈) close to feasible, and custom-character(∈) close to optimal.


A description of the QIPM algorithm is provided herein along with the following new observations:

    • Classical costs: The IPM uses custom-character(√{square root over (r)} log(1/∈)) iterations. In the classical case, when solving the PO problem via SOCP with an IPM, the cost of an iteration is dominated by the time used to solve a linear system of size L×L, which is custom-character(N3) if done via Gaussian elimination, since L˜custom-character(N) in the PO problem. In the quantum case, this step is performed quantumly. However, even in the quantum case, some classical costs are incurred: the left-hand and right-hand sides of the Newton system in eq. (19) and eq. (22) are classically computed to load this classical data into quantum circuits that perform the QLSS and tomography to gain a classical estimate of the solution to the linear system. In particular, constructing the linear system includes classical matrix-vector multiplication to compute the residuals on the right-hand-side of the Newton system in eq. (19). If the SOCP constraint matrix A is custom-character(N)×N and the number of cones r=custom-character(N), then this classical matrix-vector multiplication takes custom-character(N2) time in each of the custom-character(√{square root over (N)}) iterations. Thus, the QIPM uses at least custom-character(N2.5) classical time. Additionally, in the resource counts the minimal depth block-encoding circuits from Reference Clader are used, which use N2poly log(1/ε) classical time per iteration (although this can be parallelized) to compute angles and corresponding gate sequences to precision ε. These classical costs limit the maximum possible speedup of the QIPM over the classical IPM, but if the quantum subroutine is sufficiently fast that classical matrix-vector multiplication and angle computation is the bottleneck step, then this is a good signal for the utility of the QIPM.
    • Preconditioning: Since the runtime of the QLSS depends on the condition number of the matrix G that appears in the linear system Gu=h, it is worth examining preconditioning techniques for reducing the condition number. In the implementation proposed, a simple form of preconditioning may be preformed. Let D be a diagonal matrix where entry Dii is equal to the norm of row i of the matrix G. Instead of solving the linear system Gu=h, solve the equivalent system (D−1G)u=D−1h. Note that D−1G and D−1h can each be classically computed in custom-character(N2) time, roughly equal to the time used to compute h in the first place (see previous bullet), so this step is unlikely to be a bottleneck in the algorithm. In the numerical experiments herein, the condition number of D−1G is typically more than an order of magnitude smaller than G, and sometimes several orders of magnitude (see FIG. 9 in section VI).
    • Norm of linear system and step length: As discussed in section IV B, QLSSs produce a normalized state |u>, where u is the solution to Gu=h, and quantum state tomography on |ucustom-character can only reveal the direction of the solution u and not its norm. The norm can be estimated separately with a comparable amount of resources, but in the context of QIPMs, it is not necessary to learn the norm of the solution. If the direction of the solution is known, the amount by which to update the vector in that direction can be determined classically in custom-character(N) time as follows. If (Δx; Δy; Δτ; Δθ; Δs; Δκ) is the normalized solution to the Newton linear system in eqs. (19) and (22), then the amount to step in that direction is equal to












μ

(

x
,
τ
,
s
,
κ

)



(

1
-
σ

)



(

r
+
1

)





-


(

Δ

x

)

T



s

-



(

Δ

s

)

T


x

-


(

Δ

κ

)


τ

-


(

Δ

τ

)


κ



.




(
64
)







This expression is chosen such that the duality gap of the new point is (e.g., exactly) a factor of σ smaller than the old point, up to deviations that are second order in the step length. Note that if the old point is feasible and the solution to the linear system is exact, the second and higher order contributions vanish anyway.

    • Adaptive tomographic precision and neighborhood detection: In conventional work, the choice of tomography precision parameter is determined by a formula that aimed to guarantee staying within the neighborhood of the central path under a worst-case outcome. However, since determining whether a point is within the neighborhood of the central path can be done in classical custom-character(N) time (see section III C 6), the tomography precision parameter ξ herein may instead be determined adaptively for optimal results. For example: start with ξ=½, solve the linear system to precision ξ and check if the resulting point is within the neighborhood of the central path. If yes, continue to the next iteration; if no, repeat the tomography with ξ←ξ/2. Since the complexity of tomography is custom-character(1/ξ2), the cost of this adaptive scheme is proportional to a geometric series 4+16+64+ . . . +custom-character(1/ξ2) of which the final term makes up most of the cost (accordingly, for simplicity, the resource calculation may only account for the final term). This cost could be much lower than the theoretical value if the typical errors are not as adverse for the IPM as a worst-case error of the same size.


The pseudocode in Algorithm 1 illustrates the “infeasible” version of the example algorithm (II-QIPM from table II). The numbers on the left refer to steps of Algorithm 1. Text in Algorithm 1 bookended by “/*” and “*/” are comments on one or more of the steps. To implement the feasible versions (IF-QIPM and IF-QIPM-QR), minor modifications are made to reflect the process described in section III.












Algorithm 1: Quantum Interior Point Method

















Input: SOCP instance (A, b, c), list of cone sizes (N1, ··· , Nr) and tolerance ϵ



Output: Vector x that optimizes objective function (eq. (5)) to precision ϵ



/* For portfolio optimization, A, b, c are given in eq. (10). First n










entries of x give optimal stock weights.
*/


1
(x;y;τ;θ;s;κ) ← (e; 0;1;1;e;1)
/* initialize on central path */





2





μ

1

,

σ


1
-


1

20


2





1

r





,

γ


1
/
10






   /* set parameters */





3
while μ ≥ ϵ:
  /* Follow central path until




   duality gap less than ϵ */





4                     5




|




G


(



0



A





-
c




c
_



I


0





-
A



0


b



-

b
_




0


0





c





-

b





0



-

z
_




0


1





-


c
_








b
_






z
_



0


0


0




S


0


0


0


X


0




0


0


κ


0


0


τ



)







h


(


















-

A




y

+

c

τ

-


c
_


θ

-
s






Ax
-

b

τ

+


b
_


θ












-

c




x

+


b



y

+


z
_


θ













c
_




x

-



b
_




y

-


z
_


τ











σμ

e

-


X
~



S
~


e










σμ
-
κτ




)









 /* from eqs. (19) and (22) */                     /* mat .-vec. mult. performed classically */













6
|
for j = 1, ... , L:
    /* preconditioning via row





        normalization */












7   8 9 10

















k






"\[LeftBracketingBar]"


G
jk



"\[RightBracketingBar]"


2










h
j




h
j

/










for


k

=
1

,


,

L
:










G
jk





G
jk

/










  /* norm of jth row of G */












11
|
Classically compute L2 angles and gate decompositions to perform block-encoding of G and state-











|
preparation of |h>



12
|
ξ ← 1



13
|
repeat
/* try smaller and smaller ξ



|

until central path is found */











14
|
|
ξ ← ξ/2



15
|
|
(Δx; Δy; Δτ; Δθ; Δs; Δκ) ←ApprSolve(G, h, ξ)






16
|
|





(

step


length

)





μ

(

σ
-
1

)



(

r
+
1

)






(

Δ

x

)




s

+



(

Δ

s

)




x

+


(
Δκ
)


τ

+


(

Δ

τ

)


κ





















17
|
|
(x′; y′; τ′; θ′; s′; κ′) ← (x; y; τ; θ; s; κ) + (step length) · (Δx; Δy; Δτ; Δθ; Δs; Δκ)










18
|
until (x′; y′; τ′; θ′; s′; κ′) ∈ N (γ)



19
|
(x; y; τ; θ; s; κ) ← (x′; y′; τ′; θ′; s′; κ′)



20

μ ← σμ










21
return x/τ









22
def ApprSolve (G, h, ξ):










23
|
L ← 2N + K + 3



24
|
δ ← 0.1



25
|
ε ← 0.9ξ



26
|
k ← 57.5Lln(6L/δ)/(ε2(1 − ε2/4))










27
|
Run tomography as described in section IV D using k applications and k controlled-applications of the



|
QLSS algorithm on the system (G, h)


28
|
return Vector {tilde over (v)}′ for which ||{tilde over (v)}′|| = 1 and ||{tilde over (v)}′ − v|| ≤ ξ with probability at least 1 − δ, where v ∝



|
G−1h









B. End-to-End Quantum Resource Estimates

The QIPM described in the pseudocode takes 20√{square root over (2)}√{square root over (r)}ln(∈−1) iterations to reduce the duality gap to ∈, where r is the number of second-order cone constraints. In the case of the portfolio optimization problem, r=3n+1, where n is the number of stocks in the portfolio. Choosing the constant pre-factor to be 20√{square root over (2)} allows us to utilize theoretical guarantees of convergence (modulo the issue of infeasibility discussed in section III C 5); however, it would not be surprising if additional optimization of the parameters or heuristic changes to the implementation of the algorithm (e.g. adaptive step size during each iteration) would lead to constant-factor speedups in the number of iterations. Since the number of iterations would be the same for both the quantum and classical IPM, these sorts of improvements would not impact the performance of the QIPM relative to its classical counterpart.


1. Quantum Circuit Compilation and Resource Estimate for Quantum Circuits Appearing within QIPM


The QIPM includes repeatedly performing a quantum circuit associated with the QLSS and measuring in the computational basis. The costs of each of these individual quantum circuits is accounted for herein. There are two kinds of circuits that are used: first, the circuit that creates the output of the QLSS subroutine, given by the state in eq. (36), and second, the circuit that creates the state used to determine the signs of the amplitudes during the tomography subroutine corresponding to a controlled-QLSS subroutine, given in eq. (49).


To simplify the analysis, first compile the circuits from the previous section into a primitive gateset that includes Toffoli gates (and multi-controlled versions of them), rotation gates, block-encoding unitaries, state-preparation and controlled state-preparation unitaries. This compilation allows combining previous in-depth resource analysis for these primitive routines (See Ref. Clader) with the additional circuits shown here.


From left to right in the U[s] circuit shown in FIG. 1, the circuits for UQh, CR0(s) (and equivalently CR1(s)), and VG in FIGS. 4 to 6, respectively. In addition to these circuits, controlled versions of them may be performed within the tomography routine to estimate the sign of the amplitudes. The controlled-U[s] gate is given in FIG. 3. The implementation of the controlled versions of CR0(s) (and equivalently CR1(s)), and VG are also depicted in FIGS. 5 and 6, respectively.


With these decompositions in place, table V reports the resources used to perform each of the two kinds of quantum circuits involved in the QIPM (which are each performed many times over the course of the whole algorithm). The resource quantities are reported in terms of the number of calls Q to the block-encoding (which scales linearly with the condition number), as well as the controlled-block-encoding and state-preparation resources given previously in tables III and IV. The expressions also depend on various error parameters which must be specified to obtain a concrete numerical value.


In section VI, after observing empirical scaling of certain algorithmic parameters, error parameters are described to arrive at a concrete number for a specific problem size.


2. Resource Estimate for Producing Classical Approximation to Linear System Solution

The resource estimates described above capture the quantum resources used for a single coherent quantum circuit that appears during the algorithm. The output of this quantum circuit is a quantum state, but the QIPM includes a classical estimate of the amplitudes of this quantum state. This classical estimate is produced through tomography, as described in section IV D, by performing k=57.5 L ln(6L/δ)/(ε2(1−ε2/4)) repetitions each of the QLSS and controlled-QLSS circuits, where ε is the desired tomography precision and δ is the probability that the tomography succeeds. In the example implementation given in Algorithm 1, fix δ=0.1. Thus, to estimate the quantum resources of a single iteration of the QIPM, the previous resource estimates reported in table V should each be multiplied by k. With P processors large enough to prepare the output of the QLSS, these k copies may be prepared in k/P parallel steps, saving a factor of P in the runtime at the expense of a factor of P additional space. The resources and scaling estimates do not account for any parallelization, and completely serial execution and runtime is assumed.


After multiplication by k, these expressions give the quantum resources used to perform the single quantum line of the QIPM, ApprSolve. This subroutine has both classical input and output and can thus be compared to classical approaches for approximately solving linear systems.



FIG. 4 is a diagram illustrating an example decomposition of the UQh gate (shown, e.g., in FIG. 1) into a state-preparation unitary Uh and multi-controlled-Toffoli gates. The reflection operator W is given by W′=Ia1L−2|1custom-charactercustom-character1|a1 ⊗|0custom-charactercustom-character0|L. Not pictured are additional ancillas that begin and end in |0custom-character and are utilized to implement the unitary Uh in shallower depth.



FIG. 5 is a diagram illustrating an example decomposition of the CR0(s) gate (top) and controlled-CR0(s) gate (bottom), as defined in eq. (55), into single qubit rotation gates and CNOTs (top) or Toffolis (bottom). The gate Ry(ϕ) is defined to map |0custom-charactercustom-charactercos(ϕ/2)|0custom-character+sin(ϕ/2)|1custom-characterand |1custom-charactercustom-character−sin(ϕ/2)|0custom-character+cos(ϕ/2)|1custom-character. The rotation angle







θ
=

2


arctan



(


1
-

f

(
s
)



f

(
s
)


)



,




where ƒ(s) given in eq. (59). The CR1(s) gate is identical but with the control bit sign flipped. Note that the Ry(±π/4) gates are Clifford conjugate to a single T or T gate.



FIG. 6 is a diagram illustrating an example decomposition of the VG unitary (top) and controlled-VG unitary (bottom), as defined in eq. (57), into calls to a standard block-encoding unitary UG and other elementary gates, using a single ancilla qubit initialized to the |0custom-character state. Not pictured are additional ancillas that begin and end in |0custom-character and are utilized to implement the unitary UG in shallower depth. custom-character


TABLE V shows quantum resources used to create the state output by the quantum linear system solver, given in eq. (36) (QLSS, left) or the state used to compute the signs during the tomography subroutine, given in eq. (49) (Controlled QLSS, right) for a square linear system of size L=custom-character. Note that these resource quantities do not yet account for the k classical repetitions used in order to perform tomography on the output state. The parameters Q and d each scale linearly with the condition number of the linear system, as defined in proposition 2. The symbols NQcbe, TDcbe, and TCcbe denote the number of logical qubits, the T-depth, and the T-count, respectively, for performing a controlled-block-encoding, as reported in table III. The symbols TDSp, and TCsp are analogous quantities for state-preparation, as reported in table IV. The parameters εar, εtsp and εz ∈(0,1] are error parameters corresponding to the gate synthesis precision used for the CR0(s) and CR1(s) rotations, controlled state-preparation step used by tomography, and the QSVT phases, respectively.











TABLE V





Resource
QLSS
Controlled QLSS







# Qubits
NQcbe + 5
NQcbe + 6


T-depth
12Q log2(1/εar) + 2(Q + d)TDcbe +
12Q log2(1/εar) + 2(Q + d)TDcbe +



4(Q + d)TDsp + Q(24 custom-character  + 31) +
4(Q + d)TDsp + Q(24 custom-character  + 36) +



3d log2(1/εz) + d(32 custom-character  − 2)
6d log2(1/εz) + d(32 custom-character  − 2) +




12 log2(1/εtsp) + 3( custom-character  − 1)


T-count
12Q log2(1/εar) + 2(Q + d)TCcbe +
12Q log2(1/εar) + 2(Q +



4(Q + d)TCsp + Q(24 custom-character  + 31) +
d)TCcbe + 4(Q + d)TCsp +



3d log2(1/εz) + d(32 custom-character  − 2)
Q(24 custom-character  + 51) +




6d log2(1/εz) + d(32 custom-character  − 2) +




12 (L − 1)log2(1/εtsp) +




16(L − custom-character  −1)









3. Estimate for End-to-End Portfolio Optimization Problem

Recall that the full QIPM algorithm is an iterative algorithm, where each iteration involves approximately solving a linear system by preparing many copies of the same quantum states. The duality gap μ, which measures the proximity of the current interior point to the optimal point, begins at 1 and decreases by a constant factor σ with each iteration. Thus, the number of iterations to reach a final duality gap ∈ is given by:










N
it

=




ln



(
ϵ
)

/
ln



(
σ
)




=





ln



(
ϵ
)



ln



(

1
-

1

2

0



2

r





)










2

0


2


ln



(

ϵ

-
1


)



r




.







(
65
)







Recall from the discussion in section III C 3 that the output of the QIPM will achieve an custom-character(∈) approximation to the optimal value of the objective function.


Pulling this all together, the resources to perform the full QIPM algorithm can be estimated, including the multiplicative factors used to perform tomography as well as the number of iterations to converge to the optimal solution. Note that the relevant condition number κF(G) and linear-system precision ξ may vary from iteration-to-iteration as the Newton matrix G changes. The overall runtime can be upper bounded using the maximum observed value of κF(G), which is denoted by κF, and minimum observed value of ξ across all iterations. At each iteration, to achieve overall precision ξ, the tomography precision ε is chosen to be just smaller than ξ (e.g., choose ε=0.9ξ), while all other error parameters (εar, εtsp, εz, etc.) are chosen to be small constant fractions of ξ, such that a total error budget of ξ is not exceeded. As the non-tomographic error parameters all appear underneath logarithms, these small constant factors will drop out of a leading order analysis, and it suffices to replace all of these error parameters with ξ.


The overall runtime may then be expressed in terms of κF, ξ, L (the size of the Newton system), and r (the number of second-order cone constraints) up to leading order and including (e.g., all) constant factors, which are reported in table VI. Recall that for the infeasible version of the QIPM acting on the self-dual embedding, L=2N+K+3, where N is the number of SOCP variables and K is the number of linear constraints. Note that in the leading order expression, it is assumed that the contributions proportional to Q=custom-characterF) dominate over terms proportional to Q=custom-characterF) at practical choices of ξ due to the large constant prefactor in the definition of Q (see proposition 2 and surrounding discussion). The left column of table I from the introduction is formed using the expressions in table VI, and substituting the corresponding relations between L and n, where n is the number of stocks in the portfolio optimization problem given in eq. (10). That is, substitute r=3n+1 and L=2N+K+3=8n+3m+6=14n+6 when m=2n is taken, where N is the number of SOCP variables, K is the number of SOCP constraints, n is the number of stocks, and m is the number of time epochs used to create the matrix M as described in section II.


TABLE VI shows leading order contribution to the logical qubit count, T-depth, and T-count for the entire QIPM, including constant factors. The parameter L denotes the size of the Newton linear system and r denotes the number of second-order cone constraints, while ∈ denotes the final duality gap that determines when the algorithm is terminated. For the infeasible QIPM running on an n-asset instance of portfolio optimization, as given in eq. (10), L=14n+6 and r=3n+1; these substitutions yield the results in table I. The parameter κF denotes the maximum observed Frobenius condition number and ξ denotes the minimum observed tomographic precision parameter across all iterations.










TABLE VI





Resource
QIPM complexity







# Qubits
4L2


T-depth
(7 × 108FL√{square root over (r)}ξ−2 log2−1) log2(L) log2FL14/27ξ−1)


T-count
(2 × 108FL3√{square root over (r)}ξ−2 log2−1) log2(L) log2Fξ−1)









VI. NUMERICAL EXPERIMENTS WITH HISTORICAL STOCK DATA

The resource expressions in table VI include constant factors but leave parameters κF and ξ unspecified. These parameters depend on the specific SOCP being solved. As a final step, numerical simulations of small PO problems can be used to study the size of these parameters for different PO problem sizes. This information enables us to give concrete estimates for the resources used to solve realistic PO problems with our implementation of the QIPM and sheds light on whether there could be an asymptotic quantum advantage.


The numerical experiments simulate the entirety of Algorithm 1. The (e.g., only) quantum part of the algorithm is to carry out the subroutine ApprSolve (G, h, ξ). The quantum algorithm for this subroutine can be simulated by solving the linear system exactly using a classical solver and then adding noise to the resulting estimated values to simulate the output of tomography. Since the tomography scheme illustrated in section IV D repeatedly prepares the same state and draws k samples from measurements in the computational basis, the result is a sample from the multinomial distribution. In the numerical simulations herein, samples from this same multinomial distribution are drawn, thus capturing tomographic noise in a more precise way than by simply adding uniform Gaussian noise, as was done in conventional work. For simplicity, this disclosure assumes that the part of the tomography protocol that calculates the signs of each amplitude correctly computes each sign. To numerically estimate resource counts, it is helpful to understand what level of precision ξ is used to stay close enough to the central path throughout the algorithm, as well as how large the Frobenius condition number κF of the Newton system is. Noteworthy, it may be desirable to know how these quantities scale with system size and duality gap μ, which decreases by a constant factor with each iteration of the QIPM.


Section III C 5 discussed three formulations of the QIPM (see table II). The first (II-QIPM) is closely related to the original formulation, which does not guarantee that the intermediate points generated by the IPM are feasible. The other two are instantiations of the inexact-feasible formulation, which uses pre-computing a basis for the null-space of the SOCP constraint matrix. The first of these computes a valid basis by hand (IF-QIPM), while the second uses a QR decomposition to determine the basis (IF-QIPM-QR). All three versions were simulated, and it was determined that the II-QIPM stayed close to the central path, despite the lack of a theoretical guarantee that this would be the case. Here the results of the II-QIPM are presented. For comparison, in the section Additional Information E, some numerical results are presented for the feasible QIPMs, which do benefit from a theoretical convergence guarantee, but have other drawbacks.


As discussed in section V A, a simple preconditioner is implemented that reduces the condition number by about at least an order of magnitude with negligible additional classical cost. Resources estimates are reported assuming a preconditioned matrix.


A. Example Instance


FIG. 7 presents as an example the results of one of the simulations. A portfolio optimization instance of eq. (3) was constructed by randomly choosing n=30 stocks from the Dow Jones U.S. Total Stock Market Index (DWCF). The following parameters were, for example, arbitrarily set to q=1, ζ=0.05-1, and it was assumed the previous portfolio w allocates weight to each stock in proportion to its market capitalization. The returns of the 30 stocks on the first m=2n=60 days in the dataset were used to construct an average return vector û and an m×n matrix M for which MTM=Σ, the covariance matrix for the stock returns, as described in section III B.


The infeasible QIPM acting on the corresponding SOCP in eq. (10) was also simulated. The figure illustrates how the simulation successfully follows the central path to the optimal solution after many iterations. The duality gap decreases with each step, and, notably, the infeasibility and distance to the central path also decrease (exponentially) with iteration. Also plotted is the tomography precision that was used to ensure that each iteration stayed sufficiently close to the central path (determined adaptively as described in the pseudocode in Algorithm 1). The plot exemplifies how, despite the lack of theoretical convergence guarantees, our simulations suggest that in practice the II-QIPM acting on the PO SOCP will yield valid solutions.



FIG. 7 is a plot illustrating simulation results of the QIPM on an SOCP instance corresponding to portfolio optimization on n=30 randomly chosen stocks using m=60 time epochs. The duality gap μ (defined in eq. (14)), the distance to the central path dF (defined in eq. (26)), and the infeasibility (defined as the norm of the residual on the right-hand-side in eq. (19)) each decrease exponentially with the number of iterations. The tomography precision ξ to stay near the central path (defined adaptively as outlined in Algorithm 1) initially decreases and then plateaus at about 10−2.


Remarkably, for this instance, observe that both the Frobenius condition number κF and the inverse tomography precision ξ−1 initially increase but ultimately plateau with the iteration number, even as the duality gap gets arbitrarily small (see FIG. 8 for data on κF). This scaling behavior was a generic feature of the simulations across all the instances simulated. This contrasts with the worst-case expectation that the condition number can increase as κFcustom-character(1/μ) or κF=custom-character(1/μ2) (depending on the formulation of the Newton system). Prior literature does not say much about whether the quantity ξ−1 should be expected to diverge. One might expect that, since the neighborhood of the central path gets smaller as μ gets smaller (e.g., radius is proportional to μ in eq. (27)), the precision requirement to stay close to the central path would get more stringent in proportion to μ. However, recall that the step size from one iteration to the next also shrinks with μ, and that ξ represents the size of the error on the normalized Newton system solution; thus the neighborhood does not shrink relative to the distance to the optimum and the length of the next step, and there is no immediate reason that ξ−1, as defined, must diverge as μ→0. However, one does expect that in the worst case, if the condition number κ diverges, then ξ−1 should also diverge, as errors of constant size on the estimate of u/∥u∥ can lead to residual errors of divergent size κξ on the normalized product Gu/∥Gu∥.



FIG. 8 includes plots of the Median Frobenius condition κF number for 128 randomly sampled stock portfolios from the DWCF index as a function of the duality gap for portfolios of size 60, 80, 100, and 120 stocks. The shaded regions indicate the 16th to 84th percentile. Observe that the condition number appears to plateau at small values of the duality gap.


B. Scaling of Condition Number

To understand the problem scaling with portfolio size, example problem instances are generated by randomly sampling n stocks from the DWCF, using returns over m=2n time epochs (days) to construct our SOCP as in eq. (10). Parameters q, ζ, w, û and M are all chosen in the same way as described above. The Frobenius condition number of the Newton matrix is plotted as well as the preconditioned Newton matrix as a function of the duality gap in FIG. 8 for portfolios of size n∈{60, 80, 100, 120}. As previously mentioned, the condition number appears to plateau at a certain value of the duality gap, especially for the preconditioned matrix.


To help understand the asymptotic scaling of the quantum algorithm it may be helpful is to determine how the condition number scales as a function of the number of assets, as the runtime of the QLSS algorithm grows linearly with the condition number. FIG. 9 plots the Frobenius condition number κF as a function of n, the number of stocks, observed at duality gaps μ∈{10−1, 10−3, 10−5, 10−7}. At duality gaps of 10−5 and 10−7, the condition number κF has plateaued as observed in FIG. 8. A non-linear fit to the data is performed using a power law κF anb model, where a and b are fit parameters, and the exponents b are reported in table VII. All exponents appear to be near or less than unity.



FIG. 9 is a plot of the Median Frobenius condition number κF for 128 randomly sampled stock portfolios from the DWCF index as a function of portfolio size for duality gaps of 10−1, 10−3, 10−5, and 10−7. The shaded regions correspond to the 16th to 84th percentile. The lines represent power-law fits of the form anb, where the values for b are reported in table VII. In all four cases, the exponent is less than 1 and in the latter three cases it is greater than 0.9 suggesting a nearly linear-in-n trend.


C. Scaling of Tomography Precision

While the depth of the individual quantum circuits that compose the QIPM scales only with the Frobenius condition number, the QIPM also includes a number of repetitions of this circuit for tomography that scales as 1/ξ2, the inverse of the tomography precision squared. To see how this scales with problem size, an analysis for ξ−2 is performed similar to the analysis performed for κF. These results are presented in FIG. 10 for the same four duality gaps of {10−1, 10−3, 10−5, 10−7}. To reduce the iteration-to-iteration variation in the tomography precision (which results from our adaptive approach to tomography in Algorithm 1), in calculating ξ−2 at duality gap μ, one may take the average over the value of ξ−2 at the five iterations with duality gap nearest to μ. The median of ξ−2 can be fit at each value of n to a linear model on a log-log plot, corresponding to a relationship ξ−2=anb. The implied exponent b is in table VIII. In this case, it is hard to draw robust conclusions from the fits. The fit suggests that the median of ξ−2 is increasing with n on the interval n∈[10, 120]. However, the most striking feature of the data is that the instance-to-instance variation of ξ−2 is significantly larger than that of κF. In fact, at μ=10−7, the 84th percentile of in stances at n=10, the smallest size simulated, had a larger value of ξ−2 than the 50th percentile of instances at n=120, the largest size simulated.



FIG. 10 is a plot of the median value of the square of the inverse tomography precision ξ−2 used to remain in the neighborhood of the central path for 128 randomly sampled stock portfolios from the DWCF index as a function of portfolio size for duality gaps of 10−1, 10−3, 10−5, and 10−7. To reduce iteration-to-iteration variation, an artifact of the adaptive approach to tomography, average over the observed value of ξ−2 at the five iterations for which the duality gap is nearest the indicated value. The shaded regions correspond to the 16th to 84th percentile. Here logarithmic axes are used since (unlike for κF) instance-to-instance variation covers multiple orders of magnitude even for a fixed value of n. The dashed lines correspond to a linear fit to the log-log data, where the slope is reported in table VIII.









TABLE VII







Estimated exponent parameters for the Frobenius condition number


κF obtained from the fits that are plotted in FIG. 9.










Duality Gap
Condition Number Scaling






10−1

custom-character  (n0.60±0.02)




10−3

custom-character  (n0.94±0.04)




10−5

custom-character  (n0.92±0.04)




10−7

custom-character  (n0.91±0.05)

















TABLE VIII







Estimated exponent parameters for 1/ξ2 obtained


from the fits that are plotted in FIG. 10.










Duality Gap
Tomography Scaling






10−1

custom-character  (n−0.19±0.05)




10−3

custom-character  (n1.10±0.06)




10−5

custom-character  (n0.79±0.11)




10−7

custom-character  (n1.16±0.10)










D. Asymptotic Scaling of Overall Runtime

Above fits for κF and ξ−2 as a function of n on the range n ∈[10, 120] are provided. Here the quantity n1.5κF2 is studied, which determines the asymptotic scaling of the runtime of the QIPM. FIG. 11 plots this quantity at the same four duality gap values μ∈{10−1, 10−3, 10−5, 10−7}. The implied exponents arising from linear fits on a log-log axis are reported in table IX. They are generally consistent with summing the exponents from the previously reported fits. The data inherit from ξ−2 the feature that the instance-to-instance variation is orders of magnitude larger than the median. Taken at face value, the fits suggest that the scaling of the median algorithmic runtime on the interval n∈[10, 120] is similar to the n3.5 scaling of classical IPMs using Gaussian elimination, and worse than the asymptotic n2.87 arising from classical IPMs using fast matrix-multiplication techniques to solve linear systems (note that this scaling does not apply until n becomes very large, so it is not a good practical comparator). However, the large variance and imperfect fits do not give confidence that these trends can be reliably extrapolated to larger n. Accordingly, when actual resource counts are computed in the next subsection, the inventors stick to n=100.


Ultimately, it is not essential to pin down the asymptotic scaling of the algorithm, because a determination of this work is that, even if a slight asymptotic polynomial speedup exists, the size of the constant prefactors involved in the algorithm preclude an actual practical speedup, barring significant improvements to multiple aspects of the algorithm. The next subsection elaborates on this point in a more quantitative fashion.



FIG. 11 is a plot of the median value of the estimated algorithm scaling factor computed as the median of n1.5κF2 for 128 randomly sampled stock portfolios from the DWCF index as a function of portfolio size for duality gaps of 10−1, 10−3, 10−5, and 10−7. As in FIG. 10, over 5 consecutive points are averaged to reduce iteration-to-iteration variance deriving from adaptive tomography. Also, the actual number of observed samples are used that were used to achieve sufficient tomographic precision in place of the tomographic factor n/ξ2. The shaded regions correspond to the 16th to 84th percentiles. The lines correspond to a linear fit to the log-log data, where the slope is reported in table IX.


TABLE IX shows exponent parameter estimates from the fits to the line generated by plotting n1.5κF2 in FIG. 11, which determines the overall scaling of the runtime of the QIPM. For comparison, CIPMs using Gaussian elimination have runtime custom-character(n3.5) and CIPMs using faster methods for solving linear systems have runtime custom-character(n2.87).











TABLE IX






Duality Gap
Algorithm Scaling








10−1

custom-character  (n2.01±0.05)




10−3

custom-character  (n3.56±0.07)




10−5

custom-character  (n3.36±0.14)




10−7

custom-character  (n3.75±0.12)










E. Numerical Resource Estimates

Rather than examine algorithmic scaling, actual resource counts for the QIPM applied to PO are computed. It is these resource counts that may matter most from a practical perspective. The total circuit size is estimated in terms of the number of qubits, T-depth, and T-count for a portfolio of 100 assets. This size is chosed because it is small enough that the entire quantum algorithm can be simulated classically. However, at this size, solving the PO problem is not classically hard; generally speaking, the PO problem becomes challenging to solve with classical methods when n is on the order of 103 to 104. A similar concrete calculation can be performed at larger n by extrapolating trends observed in the numerical simulations herein, but there is not confidence that the fits on n∈[10, 120] reported above are reliable predictors for larger n.


Recall that the only step in the QIPM performed by a quantum computer is the task of producing a classical estimate to the solution of a linear system to error ξ. The complexity of this task as it is performed within the QIPM depends on ξ as well as the Frobenius condition number κF. The first step of the calculation is to fix values for ξ and κF at n=100. They are choosen by taking the median over the 128 samples in the numerical simulation at duality gap μ=10−7.


Once κF and ξ are fixed, concrete values for the various other error parameters can be determined that appear in the algorithm such that overall error ξ can be achieved. Tomography dominates the complexity and overall error, but there are a number of other factors that contribute to the error in the final solution. The sources of error are enumerated and labeled here for completeness:

    • εG: Error in block-encoding the matrix G
    • εh: Error in the unitary that prepares the state |hcustom-character
    • εar: Gate synthesis error for single-qubit rotations used by CR0(s) and CR1(s) (see FIG. 5)
    • ε: Tomography error
    • εz: Gate synthesis error for each single-qubit rotation used for QSVT eigenstate filtering (see FIG. 2)
    • εqsp: Error due to polynomial approximation in eigenstate filtering
    • εtsp: Error in preparing the state Σi=1L√{square root over (pi)}|icustom-character used for computing the signs in the tomography routine custom-character


Section IV described a quantum circuit that prepares a state |{tilde over (v)}custom-character (after postselection) for which ∥|{tilde over (v)}custom-character−|vcustom-character∥≤εQLSP. If the block-encoding unitaries, state-preparation unitaries, and single-qubit rotations were perfect, then the only contribution to εQLSP would be from eigenstate filtering and we may have εQLSP≤εqsp. Note the relationship d=2κF ln(2/εqsp) from proposition 2. Since the block-encoding unitary UG, the state-preparation unitary Uh, and the single-qubit rotations are implemented imperfectly, there is additional error. In preparing the state, the unitary UG is called 2Q+2d times and the unitary Uh is called 4Q+4d times, where Q is given in proposition 2. Additionally, there are 2Q combined appearances of CR0(s) and CR1(s) gates, where each appearance includes two single-qubit rotations. Note that the appearances of CR0(s) and CR1(s) within the eigenstate filtering portion of the circuit do not contribute to the error because at s=1 these gates can be implemented exactly. Additionally, there are another d single-qubit rotations used to implement the eigenstate filtering step. Since operator norm errors add sublinearly, one can thus say that





εQLSP≤εqsp+(2Q+2dG+(4Q+4dh+4ar+2z.  (66)


Now, the result of proposition 4 implies that, in order to assert that the classical estimate {tilde over (v)}′ output by tomography satisfies ∥{tilde over (v)}′−v∥≤ξ, it suffices to have





ξ≥ε+1.58√{square root over (L)}εtsp+1.58[εqsp+(2Q+2dG+(4Q+4dh+4ar+dεz],   (67)


where for convenience recall the definitions (ignoring the custom-character(√{square root over (κF)}) term) of Q and d as






Q=2F  (68)






d=F ln(2/εqsp)  (69)


Recalling that the dominant term in the complexity of the algorithm scales as ε−2 but logarithmically in the other error parameters, to minimize the complexity assign the majority of the error budget to ε: let ε=0.9ξ, and split the remaining 0.1ξ across the remaining six terms of eq. (67). There is room for optimizing this error budget allocation, but the savings would be at most a small constant factor in the overall complexity.


Note that elsewhere in the draft, ξ has been referred to as “tomography precision” since ε will dominate the contribution to ξ. Here, the resource calculation uses differentiating ε from ξ, but when speaking conceptually about the algorithm, one can focus on ξ as it is the more fundamental parameter: it represents the precision at which the classical-input-classical-output linear system problem is solved, allowing apples-to-apples comparisons between classical and quantum approaches.


With values for κF, εG, εh, εqsp, εz, and εtsp now fixed, the resource count can be completed using the expressions in table V. Note that for gate synthesis error, the following formula is used Ry=3 log2(1/εr), where Ry is the number of T gates used to achieve an εr-precise Clifford+T gate decomposition of the rotation gate. Putting this all together yields the resource estimates for a single run of the (uncontrolled) quantum linear system solver in table X at n=100. We report these estimates both in terms of primitive block-encoding and state-preparation resources, as well as the raw numerical estimates. For the total runtime, the resources used for the controlled state-preparation routine may also be estimated. These quantities are estimated, but to the precision of the reported estimates, the numbers are the same as the controlled version, so they are excluded for brevity.


To estimate total runtime, our estimates are multiplied by the tomography factor k (for controlled and for uncontrolled) as well as the number of iterations Nit=┌ ln(∈)/ln(σ)┐, where ∈ is the target duality gap (which is taken to be ∈=10−7), and σ=1.0−1/(20 √{square root over (2r)}). While k will vary from iteration to iteration, in the calculation it is assumed that the total number of repetitions is given by the simple product (2k)Nit, which, noting that the value of ξ plateaus after a certain number of iterations, will give a roughly accurate estimate. Note that these 2kNit repetitions need not be done coherently, in the sense that the entire system is measured and reprepared in between each repetition. One can bound the tomography factor k to be k≤57.5 L ln(L)/ξ2, where ξ is determined empirically. However, our numerical simulations of the algorithm yield an associated value of k used to generate the estimate to precision ξ, so this numerically determined value can be used directly. The observed median value of k=3.3×108 from simulation is multiple orders of magnitude smaller than the theoretical bound. Using this substitution for k and Nit, the results are shown in the right column of table I in the introduction.


To aid in understanding which portions of the algorithm dominate the complexity, a breakdown of the resources is shown in FIG. 12. The width of the boxes is representative of the T-depth, while the height of the boxes represents the T-count. The number of classical repetitions, composed of tomography samples as well as IPM iterations used to reach a target duality gap, contributes the largest factor to the algorithmic runtime. Of these two, quantum state tomography contributes more than the iterations used to reach the target duality gap. Our exact calculation confirms that for the individual quantum circuits involved in the QLSS, the discrete adiabatic portion of the algorithm dominates over the eigenstate filtering step in its contribution to the overall quantum circuit T-depth. Within the adiabatic subroutine, the primary driver of the T-depth and T-count is the application of the block-encoding operator Q times (see e.g., eq. (61)), where Q is proportional to the Frobenius condition number. An additional source of a large T-count arises from block-encoding the linear system, which causes the T-count to scale as custom-character(L2).


TABLE X shows estimated number of logical qubits NQ, T-depth TD, and T-count TC used to perform the quantum linear system solver (QLSS) subroutine within the QIPM running on a PO instance with n=100 stocks. This calculation uses the empirically observed median value for the condition number at duality gap μ=10−7, which was κF=1.6×104. The full QIPM repeats this circuit k=custom-character(nln(n)ξ−2) times in each iteration to generate a classical estimate of the output of the QLSS, and also performs Nit=custom-character(n0.5) iterations, where the linear system being solved changes from iteration to iteration. In the left column, the resources are written as numerical prefactors times the resources used to perform the controlled-block-custom-characterencoding of the matrix G (denoted by a subscript cbe), and the state-preparation of the vector |hcustom-character (denoted by a subscript sp), defined in tables III and IV. Written this way, one can see the large prefactors occurring from the linear system solver portion of the algorithm. In the right column the exact resources are computed, including those coming from the block-encoding. The notation AeB is short for A×10B.











TABLE X






QLSS Prefactors
Total








NQ = NQcbe + 5
NQ = 8e6



TD = (1e8)TDcbe + (3e8)TDsp + (5e10)
TD = 4e11



TC = (1e8)TCcbe + (3e8)TCsp + (5e10)
TC = 2e17









VII. CONCLUSIONS
A. Bottlenecks

The resource quantities reported are large, even for the classically easy problem size of n=100 assets in the portfolio optimization instance. Our detailed analysis allows us to see exactly how this large number arises, which is helpful for understanding how to improve it. Several independent factors leading to the large resource estimates are outlined below.

    • The block-encoding of the classical data may be called many times by the QLSS. This data is arranged in an L×L matrix (note that for a PO instance of size n with m=2n, the Newton linear system has size roughly L≈14n). These block-encodings can be implemented up to error εG in custom-character(log(L/εG)) T-depth using circuits for quantum random access memory (QRAM) as a subroutine. While the asymptotic scaling is favorable, after close examination of the circuits for block-encoding, in practice the T-depth can be quite large: at n=100 and εG 10−10 (it may be necessary to take εG very small since the condition number of G is quite large), block-encoding to precision εG has a T-depth of nearly 1000. Notably, this T-depth arises even after implementing several new ideas to minimize the circuit depth.
    • The condition number κF determines how many calls to the block-encoding are to be made, and it is observed that κF may be quite large for the application of portfolio optimization. Even after an preconditioning, κF is on the order of 104 already for small SOCP instances corresponding to n=100 stocks, and empirical trends suggest it grows nearly linearly with n. However, additional preconditioning may significantly reduce the effective value of κF in this algorithm.
    • The constant factor in front of the custom-characterF) in QLSSs is also quite large: the theoretical analysis proves an upper bound on the prefactor of 3×104. Numerical simulations previously performed suggested that, in practice, it can be one order of magnitude smaller than the theoretical value. Thus, the constant prefactor may be taken to be 2000 in the numerical estimates herein, which still contributes significantly to the estimate.
    • Pure state tomography includes preparing many copies of the output |vcustom-character of the QLSS. This disclosure improved the constant prefactors in the theoretical analysis beyond what was known, but even with this improvement, the number of queries used to produce an estimate v′ of the amplitudes of |vcustom-character up to error ε in custom-character2 norm is 115 L ln(L)/ε2, which for n=100 and ε=10−3 is on the order of 1011 (although our simulations suggest 2k=7×108 suffice in practice).
    • QIPMs, like CIPMs, are iterative algorithms; the number of iterations in our implementation is roughly 20√{square root over (2r)} ln(∈−1), a number chosen to utilize theoretical guarantees of convergence (note that r≈3n). Taking n=100 and ∈=10−7, our implementation would use 8×103 iterations. The number of iterations may be significantly decreased if more aggressive choices are made for the step size. For example, similar to the adaptive approach to tomographic precision, one may set longer step sizes first, and shorten the step size when the iteration does not succeed. This sort of optimization may apply equally to CIPMs and QIPMs.


Remarkably, the five factors described above contribute roughly equally to the overall T-depth calculation; the exception being the number of copies used to do tomography, which is a much larger number than the others. Another comment regarding tomography is that, in principle, the k tomographic samples can be taken in parallel rather than in series. Running in parallel leads to a huge overhead in memory: one can reduce the tomographic depth by a multiplicative factor P at the cost of a multiplicative factor P additional qubits. Note that even preparing a single copy uses the large number of nearly ten million logical qubits at n=100. Moreover, it is unlikely that improvements to tomography alone may make the algorithm practical, as the other four factors still contribute roughly 1016 to the T-depth.


Besides the rather large constant factors pointed out above for tomography and especially for the QLSS, note that the multiplicative “log factors” that are typically hidden underneath custom-character notation in asymptotic do tomography, which is a much larger number than the analyses contribute meaningfully here. For instance, the entire block-encoding depth is custom-character(log(n/εG)), which, in practice, is as large as 1000. Moreover, there is an additional ln(∈−1)≈16 coming from the iteration count, and a ln(L)≈7 from tomography.


This quantitative analysis of bottlenecks for QIPMs can inform likely bottlenecks in other applications where QLSS, tomography, and QRAM subroutines are used. While some parameters such as κF and ξ are specific to the application considered here, other observations such as the numerical size of various constant and logarithmic factors (e.g., block-encoding depth) would apply more generally in other situations.



FIG. 12 is a diagram illustrating the breakdown of the quantum resources used for a single coherent run of the uncontrolled version of the quantum algorithm used to produce the state eq. (36). As in table X, take the final duality gap to be μ=10−7 and the number of assets to be n=100. Choices for the Frobenius condition number κF=1.6×104 and number of tomographic repetitions k=3.3×108 are informed by our numerical experiments, as discussed in section VI. A similar breakdown for the controlled version used to produce the state eq. (49) would be basically the same. The eigenstate filtering sub-circuit follows a similar alternating structure to the adiabatic evolution, with the U[j] block-encodings replaced with either U[1] or U[1], the reflection operator W replaced with phase rotations, and only d<<Q total number of iterations (refer to FIG. 2 for details.)


B. Resource Estimate Given Dedicated QRAM Hardware

The bottlenecks above focused mainly on the T-depth and did not take into account the total T-count or the number of logical qubits, which are also large. Indeed, the estimate of 8 million logical qubits, as reported in table I, is drastically larger than estimates for other quantum algorithms, such as Shor's algorithm and algorithms for quantum chemistry, both of which can be on the order of 103 logical qubits. By contrast, the current generation of quantum processors have tens to hundreds of physical qubits, and no logical qubits; a long way from the resources used for this QIPM.


However, note that, as for other algorithms using repeated access to classical data, the vast majority of the gates and qubits in the QIPM arise in the block-encoding circuits, which are themselves dominated by QRAM-like data-loading subcircuits. These QRAM-like sub-circuits have several special features. Firstly, they are largely composed of controlled-swap gates, each of which can be decomposed into four T gates that can even be performed in a single layer, given one additional ancilla and classical feed-forward capability. Furthermore, in some cases, the ancilla qubits can be “dirty”, i.e., initialized to any quantum state, and, if designed correctly, the QRAM circuits can possess a natural noise resilience that may reduce the resources used for error correction. Implementing these circuits with full-blown universal and fault-tolerant hardware could be unnecessary given their special structure. Just as classical computers have dedicated hardware for RAM, quantum computers may have dedicated hardware optimized for performing the QRAM operation. Preliminary work on hardware based QRAM data structures (as opposed to QRAM implemented via quantum circuits acting on logical qubits) shows promise in this direction.


Our estimates suggest that the size of the QRAM used to solve an n=100 instance of PO is one megabyte, and the QRAM size for n=104 (i.e., sufficiently large to potentially be challenging by classical standards) is roughly 10 gigabytes, which is comparable to the size of classical RAM one might use on a modern laptop. These numbers could perhaps be reduced by exploiting the structure of the Newton matrix, as certain blocks are repeated multiple times in the matrix, and many of the entries are zero (see eqs. (10) and (19)). Exploiting the sparsity of the matrix can lead to reduced logical qubit count and T-count, but not reduced T-depth. In fact, it may lead to non-negligible increases in the T-depth, since the shallowest block-encoding constructions can be hyper-optimized for low-depth, and are explicitly not compatible with exploiting sparsity.


With this in mind, one can ask the following hypothetical question: suppose access to a sufficiently large dedicated QRAM element in our quantum computer, and furthermore that the QRAM ran at a 4 GHz clock speed (which is comparable to modern classical RAM); would the algorithm become more practical in this case? Under the conservative simplifying assumption that each block-encoding and state-preparation unitary uses just a single call to QRAM and the rest of the gates are free, a rough answer can be given by referring to the expression in table X, which states that 4×108 total block-encoding and state-preparation queries are used. Thus, even if the rest of the estimates stay the same, the number of QRAM calls involved in just a single QLSS circuit for n=100 would be 4×108. Accounting for the fact that the QIPM involves an estimated 6×1012 repetitions of similarly sized circuits, the overall number of QRAM calls used to solve the PO problem would be larger than 1021, and the total evaluation time would be on the order of ten thousand years. Thus, even at 4 GHz speed for the QRAM, the problem remains decidedly intractable. Nonetheless, if the QIPM is made practical, it may involve specialized QRAM hardware in combination with improvements to the algorithm itself. Separate from the QLSS, a relatively small number of state preparation queries is used in tomography to create the state in eq. (50), but this number does not scale with K and it is neglected in this back-of-the-envelope analysis.


C. Comparison Between QIPMs and CIPMs and Comments on Asymptotic Speedup

The discussion above suggests that the current outlook for practicality with a QIPM is pessimistic, but simultaneously highlights several avenues by which to improve the results. Even with such improvements, if QIPMs are to one day be practical, they may need to at least have an asymptotic speedup over CIPMs. Here we comment on this possibility. A step of both QIPMs and CIPMs is the problem of computing a classical estimate of the solution to a linear system, a task that is also of broad use beyond interior point methods. Thus, we can compare different approaches to solving linear systems, and our conclusions are relevant in any application where linear systems are solved. Accordingly, in table XI, the asymptotic runtime of several approaches to solving an L×L linear system to precision are given, including the (QLSS+tomography) approach utilized by QIPMs, as well as two classical approaches. Whereas prior literature primarily compared against Gaussian elimination (which scales as custom-character(L3)), this disclosure notes a comparison against the randomized Kaczmarz method, which scales as custom-character(LκF2 ln(ξ−1)). This scaling comes from the fact that 2κF2 ln(ξ−1) iterations are used, and each iteration involves computing several inner products at cost custom-character(L). It is observed that the worst-case cost of an iteration is 4L floating point multiplications, meaning all the constant prefactors involved are more-or-less mild. Thus, the asymptotic quantum advantage of the QIPM is limited to an amount equal to custom-character(min(ξ2κF, ξ2L2F)), which is at most custom-character(L) when κF ∝L and ξ=O(1). Encouragingly, our numerical results are consistent with κF ∝L. However, our results are not consistent with ξ=custom-character(1), suggesting instead that ξ is decreasing with L.


TABLE XI shows a comparison of time complexities of different approaches for exactly or approximately solving an L×L linear system with Frobenius condition number κF to precision ξ. The comparison highlights how a quantum advantage only persists when κF is neither too large nor too small. The constant pre-factor roughly captures the T-depth determined for the quantum case (the same pre-factor from Tab. VI after discounting the 20√{square root over (2)} IPM iteration factor) and the number of multiplications in the classical case.












TABLE XI








Pre-factor


Solver
Type
Complexity
estimate







QLSS +
Quantum,
Fξ−2
5 × 107


Tomography
Approximate
ln(L) ln (κFξ−1L14/27)



Gaussian
Classical,
L3



Elimination
Exact




Randomized
Classical,
F2ln(ξ−1)
8


Kaczmarz
Approximate









If κF ∝L and ξ=custom-character(1), it is determined a total QIPM runtime of custom-character(n2.5), improving over classical custom-character(n3.5) for a portfolio with n stocks. This speedup is a material asymptotic improvement over the classical complexity, but leveraging this speedup for a practical advantage might still be difficult. Firstly, the difference in the constant prefactor between the quantum and classical algorithms would likely negate the speedup unless n is taken to be very large. Secondly, the speedup would necessarily be sub-quadratic. In the context of combinatorial optimization, where quadratic speedups can be obtained easily via Grover's algorithm, even a quadratic speedup is unlikely to exhibit actual quantum advantage after factoring in slower quantum clock speeds and error-correction overheads.


Our results suggest that determining a practical quantum advantage for portfolio optimization might require structural improvements to the QIPM itself. In particular, it may be helpful to explore whether additional components of the IPM can be quantized, and whether the costly contribution of quantum state tomography could be completely circumvented. Naively, circumventing tomography entirely is challenging, as it is useful (e.g., important) to retrieve a classical estimate of the solution to the linear system at each iteration in order to update the interior point and construct the linear system at the next iteration. Nevertheless, tomography represents a formidable bottleneck.


While our results are pessimistic on the question of whether quantum interior point methods will deliver quantum advantage for portfolio optimization (and other applications), it is our hope that by highlighting the precise issues leading to daunting resource counts, our work can inspire innovations that render quantum algorithms for optimization more practical. Finally, we conclude by noting that detailed, end-to-end resource estimations of the kind performed here may be helpful (e.g., important) for commercial viability of quantum algorithms and quantum applications. While it is helpful to discover and prove asymptotic speedups of quantum algorithms over classical, an asymptotic speedup alone does not imply practicality. For this, a detailed, end-to-end resource estimate is used, as the quantum algorithm may nevertheless be far from practical to implement.


VIII. ADDITIONAL INFORMATION
Additional Information A: Notation

Here we list the symbols that appear in this disclosure for reference.


Symbols related to portfolio optimization

    • n: number of stocks in the portfolio
    • w: length-n vector indicating fraction of portfolio allocated to each stock (the object to be optimized)
    • w: length-n vector indicating current portfolio allocation
    • ζ: length-n vector indicating maximum allowable change to portfolio
    • û: length-n vector of average returns
    • Σ: n×n covariance matrix capturing deviations from average returns
    • q: parameter in objective function that determines relative weight of risk vs. return (eq. (3))
    • M: m×n matrix corresponding to the square-root of Σ, i.e. Σ=MTM
    • m: number of rows in M, often equal to the number of time epochs (section III B)


Symbols related to second-order cone programs

    • custom-character: second-order cone of dimension k (eq. (4))
    • custom-character: product set of several second-order cones
    • e: identity element for custom-character or custom-character (depending on context)
    • N: total number of variables in the SOCP
    • K: total number of linear constraints in the SOCP
    • r: number of second-order cone constraints in the program
    • x: length-N vector; primal variable to be optimized, constrained to custom-character
    • y: length-K vector; dual variable to be optimized
    • s: length-N vector, appears in dual program, constrained to custom-character
    • A: K×N matrix encoding linear constraints (eq. (5))
    • b: length-K vector encoding right-hand side of linear constraints (eq. (5))
    • c: length-N vector encoding objective function (eq. (5))
    • μ(x, s): duality gap of the primal-dual point (x, s) (eq. (7))
    • τ, κ, θ: additional scalar variables introduced to implement self-dual embedding (e.g., see section III C 3)
    • μ(x, τ, s, κ): duality gap of the point (x, τ, s, κ) of the self-dual SOCP (eq. (14))
    • X, S: arrowhead matrices for vectors x and s (eq. (21))
    • B: basis for null space of self-dual constraint matrix


Symbols related to second-order cone programs for portfolio optimization

    • ϕ: length-n variable introduced during reduction from PO to SOCP; part of x (eq. (10))
    • ρ: length-n variable introduced during reduction from PO to SOCP; part of x (eq. (10))
    • t: scalar variable introduced during reduction from PO to SOCP; part of x (eq. (10))
    • η: length-m variable introduced during reduction from PO to SOCP; part of x (eq. (10))


Symbols related to interior point methods (IPMs)

    • v: parameterizes central path (eq. (12))
    • dF (x, τ, S, κ): distance of the point (x, τ, s, κ) to the central path of the self-dual SOCP (eq. (13))
    • custom-character, custom-character, custom-characterF: neighborhoods of the “central path” (eqs. (27) and (28))
    • γ: radius of neighborhood of central path
    • σ: step length parameter
    • L: size of (square) Newton matrix
    • ∈: input to IPM specifying error tolerance, algorithm terminates once duality gap falls beneath ∈


Relations Between Parameters

    • Self-dual embedding has 2N+K+3 parameters and N+K+2 linear constraints
    • Newton matrix has size L=2N+K+3 for infeasible approach and L=N+1 for feasible approach
    • For PO formulation in eq. (10), N=3n+m+1, r=3n+1, K=2n+m+1
    • In our numerical experiments, we choose m=2n


Symbols related to quantum linear system solvers

    • G: L×L matrix encoding linear constraints
    • h: length-L vector encoding right-hand-side of linear constraints
    • u: solution to linear system Gu=h
    • v: normalized solution to linear system u/∥u∥
    • εQLSP: error in solution to linear system
    • {tilde over (v)}: normalized output of the QLSS, which should satisfy ∥v−{tilde over (v)}∥≤εQLSP
    • custom-character:┌log2 L┐
    • UG: block-encoding unitary for G
    • custom-characterG: number of ancilla qubits used by UG
    • Uh: state-preparation unitary for |hcustom-character
    • κF(G): Frobenius condition number ∥G∥F∥G−1∥ of G
    • Q: number of queries to UG and Uh (proposition 1)
    • C: constant prefactor of κF (proposition 1)
    • d: the degree of the polynomial used in eigenstate filtering (proposition 2)


Symbols related to block encoding and state preparation

    • εG: block-encoding error for matrix G
    • εh: state-preparation error for vector h
    • εar: Gate synthesis error for rotations needed by CR0(s) and CR1(s)
    • εz: Gate synthesis error for rotations needed by the QSP phases
    • εqsp: Error due to polynomial approximation in eigenstate filtering
    • εtsp: Error in preparing the state Σi=1L√{square root over (pi)}|icustom-character needed for the tomography routine
    • NQbe, TDbe, and TCbe: number of logical qubits, T-depth, and T-count required for block-encoding.
    • NQcbe, TDcbe, and TCcbe: number of logical qubits, T-depth, and T-count required for controlled-block-encoding.
    • NQsp, TDsp, and TCsp: number of logical qubits, T-depth, and T-count required for state preparation.
    • NQcsp, TDcsp, and TCcsp: number of logical qubits, T-depth, and T-count required for controlled-state preparation.


Symbols related to tomography

    • k: number of measurements on independent copies of the state
    • δ: probability of failure
    • ε: guaranteed error of tomographic estimate
    • ξ: overall precision of solution to linear system, dominated by tomographic error


Additional Information B: Deferred Proofs
1. Quantum State Tomography

Proof of proposition 3. Consider a single coordinate αj with associated probability pj=|αj|2, and suppose k samples are taken to determine an estimate {tilde over (p)}j of pj. By Bernstein's inequality,










Pr
[




"\[LeftBracketingBar]"




p
˜

j

-

p
j




"\[RightBracketingBar]"


>

ε
j


]



2


exp



(


-


ε
2


2


(


p
j

+

ε
/
3


)





k

)






(
B1
)







and so for a given component-wise target deviation in the probability εj, choosing










k




2


(


p
j

+

ε
/
3


)



ε
2




ln



(

2
/

δ



)



=



2


(





"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2

+

ε
/
3


)



ε
2




ln



(

2
/

δ



)






(
B2
)







guarantees that Pr[|{tilde over (p)}j−pj|>εj]≤δ′.


Now pick εj=√{square root over (3γ)}|αj|ε+γε2 for some yet undetermined γ>0. With this choice











2



(





"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2

+

ε
3


)



ε
2




ln



(

2
/

δ



)





(
B3
)









=



2



(





"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2

+



γ
3



ε

+


γ
3



ε
2



)




(




3

γ






"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"



ε

+

γ


ε
2



)

2




ln



(

2
/

δ



)












2



(





"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2

+

2



γ
3



ε

+


γ
3



ε
2



)



3

γ


ε
2





(




"\[LeftBracketingBar]"




α
j

|

=



"\[RightBracketingBar]"


+



γ
3



ε


)

2





ln



(

2
/

δ



)









=


2

3

γ


ε
2





ln



(

2
/

δ



)



,




and hence it suffices to choose






k
=


2

3

γ


ε
2





ln




(

2
/

δ



)

.






Letting δ′=δ/L, the union bound implies that for







k
=


2

3

γ


ε
2





ln



(

2

L
/
δ

)



,




all estimates {tilde over (p)}j satisfy |{tilde over (p)}j−pj|≤εj. Now bound the distance between |{tilde over (α)}j| and |αj|. First,













"\[LeftBracketingBar]"



α
˜

j



"\[RightBracketingBar]"


-



"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"








p
j

+
ε


-



"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"







(
B4
)









=







"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2

+



3

γ






"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"



ε

+

γ


ε
2




-



"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"












(




"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


+


γ


ε


)

-



"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"









=


γ



ε
.






Next, bound |αj|−|{tilde over (α)}j|. If pj≤εj then















"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2






3

γ






"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"



ε

+

γ


ε
2









"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"







(


3

+

7


)



γ


2


ε



,




(
B5
)











while


if



p
j


>

ε
j


,













"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


-



"\[LeftBracketingBar]"



α
˜

j



"\[RightBracketingBar]"








"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


-




p
j

-

ε
j










(
B6
)










=




"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


-






"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"


2

-



3

γ






"\[LeftBracketingBar]"


α
j



"\[RightBracketingBar]"



ε

-

γ


ε
2












<




(


3

+

7


)



γ


2


ε


,




which follows because the function ƒ(x)=x−√{square root over (x2−√{square root over (3x)}−1)} has its maximum at








f

(



3

+

7


2

)

=



3

+

7


2


.




Therefore with the choice







γ
=


(



3

+

7


2

)


-
2



,




we can guarantee that ∥{tilde over (α)}j|−|αj∥≤ε, which corresponds to









k
=



2

3

γ


ε
2





ln

(

2


L
/
δ


)


=



5
+


2

1




3


ε
2





ln

(

2


L
/
δ


)







(
B7
)







measurements.


Proof of proposition 4. Define







ε


=


1


2

L




ε




1
-


ε
2

/
4



.






Then k 2.875ε′−2 ln(6L/δ). Consider the following three assertions:

    • 1. The estimates pi satisfy |√{square root over (pi)}−|{tilde over (v)}i|√{square root over (p)}|≤ε′/3 for all i.
    • 2. The estimates pi+=ki++/k satisfy










"\[LeftBracketingBar]"




p
i
+


-




"\[LeftBracketingBar]"




p




v
˜

i


+


p
i






"\[RightBracketingBar]"


2




"\[RightBracketingBar]"





ε


/
3


,




and the estimates pi=ki/k satisfy










"\[LeftBracketingBar]"




p
i
-


-




"\[LeftBracketingBar]"




p




v
˜

i


+


p
i






"\[RightBracketingBar]"


2




"\[RightBracketingBar]"





ε


/
3


,




for all i.

    • 3. The actual amplitudes √{square root over (pi′)} of the state created in the second step satisfy |√{square root over (pi′)}−√{square root over (pi)}|≤εtsp.


From proposition 3, we know that Assertion 1 holds with probability at least 1-δ/3, and Assertion 2 holds with probability at least 1−2δ/3. Therefore both assertions hold with probability at least 1−δ. Moreover, Assertion 3 holds by assumption. From here on it is assumed that all three assertions hold.


Let ai be the real part and bi be the imaginary part of the quantity √{square root over (p)}{tilde over (v)}i. Let ri+=|√{square root over (p)}{tilde over (v)}i+√{square root over (pi)}|, and ri=|√{square root over (p)}{tilde over (v)}i−√{square root over (pi)}|. Note that ri+ and ri are proportional to the absolute value of the ideal amplitudes of the state created in eq. (50). One can show that











a
i

=




(

r
i
+

)

2

-


(

r
i
-

)

2



4



p
i





.




(
B8
)







Define ƒi(x, y)=(x2−yz)/√{square root over (pi)}; then aii(ri+/2, ri/2). Note that the estimates √{square root over (pi±)} give good approximations of ri+/2 and ri/2:













"\[LeftBracketingBar]"




p
i
±


-


r
±

2




"\[RightBracketingBar]"







ε


3


ε

+


ε

t

s

p


2



,




(
B9
)







which follows from Assertions 2 and 3. The amplitudes di that define the estimate output by the tomography algorithm are given in eq. (52), which can now be rewritten as











a
i

~

=

{





0
,







p
i






2
3



ε



+

ε

t

s

p




;

else







min


(



p
i


,


f
i



(



p
i
+


,



p
i
-



)



)



,








f
i



(



p
i
+


,



p
i
-



)



0








max


(


-


p
i



,


f
i



(



p
i
+


,



p
i
-



)



)



,






f
i



(



p
i
+


,



p
i
-



)


<
0




.






(
B10
)







We prove that the ãi values approximate the ai values, specifically





|ãi−ai|≤ε′+εtsp+|bi|.  (B11)


We will prove the claim above using a case-by-case analysis. Assume that ai≥0; the case ai<0 will proceed similarly.


First, consider the case








p
i






2
3



ε



+


ε

t

s

p


.






In this case ãi=0 and







a
i




p





"\[LeftBracketingBar]"



v
˜

i



"\[RightBracketingBar]"







p
i


+


ε


3





ε


+


ε



tsp
,





so





"\[LeftBracketingBar]"


a
i



"\[RightBracketingBar]"






ε
+


ε

t

s

p


.






Second, consider the case ƒi(√{square root over (pi+)}, √{square root over (pi)})≥ai. From the definition of ãi and Assertion 1, we have









a
i

~




p
i






p





"\[LeftBracketingBar]"



v
˜

i



"\[RightBracketingBar]"



+


ε


3



,




and thus













a
i

~

-

a
i






p





"\[LeftBracketingBar]"



v
˜

i



"\[RightBracketingBar]"



-

a
i

+


ε


3



=





a
i
2

+

b
i
2



-

a
i

+


ε


3







"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"


+



ε


3

.







(
B12
)







We also have (again invoking Assertion 1)












a
i

-


a
i

~





a
i

-


p
i






a
i

-


p





"\[LeftBracketingBar]"



v
˜

i



"\[RightBracketingBar]"



+


ε


3






ε


3


and


thus



,





"\[LeftBracketingBar]"



a
i

-


a
i

~




"\[RightBracketingBar]"







"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"


+



ε


3

.







(
B13
)







Additionally, consider the case ƒi(√{square root over (pi+)}, √{square root over (pi)})<ai. Defining








ε
˜

=



2
3



ε



+

ε
tsp



,




we can lower bound ƒi(√{square root over (pi+)}, √{square root over (pi)}): text missing or illegible when filed









?




(
B14
)









=


a
i

-


ε
~






r
i
+

+

r
i
-



2



p
i




.










?

indicates text missing or illegible when filed




Here in the second line we used eq. (B9) and the fact that







r
i
+




p
i






2
3



ε



+


ε
tsp

.






We now upper bound ri++ri:











r
+

+

r
-


=





(


a
i

+


p
i



)

2

+

b
i
2



+




(


a
i

-


p
i



)

2

+

b
i
2








(
B15
)














"\[LeftBracketingBar]"



a
i

+


p
i





"\[RightBracketingBar]"


+



"\[LeftBracketingBar]"



a
i

-


p
i





"\[RightBracketingBar]"


+

2




"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"










=


2


max

(


a
i

,


p
i



)


+

2




"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"













2


(



p
i


+


ε


/
3

+



"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"



)



,




where in the fourth line we used ai≤√{square root over (ai2+bi2)}=√{square root over (p)}|{tilde over (v)}i|≤√{square root over (pi)}+ε′/3 (Assertion 1).


Therefore,










f
i

(



p
i
+


,


p
i
-



)

=


a
i

-


ε
˜





r
i
+

+

r
i
-



2



p
i










(
B16
)












a
i

-


ε
˜




2


(



p
i


+


ε


/
3

+



"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"



)



2



p
i












=


a
i

-

ε
˜

-



ε
˜



p
i





(



ε


/
3

+



"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"



)













a
i

-

(


ε


+

ε
tsp

+



"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"



)



,




where in the fourth line we used {tilde over (ε)}/√{square root over (pi)}≤1. This implies












"\[LeftBracketingBar]"




a
~

i

-

a
i




"\[RightBracketingBar]"


=



a
i

-


a
~

i





a
i

-

min

(



f
i

(



p
i
+


,


p
i
-



)

,


p
i



)





ε


+

ε
tsp

+




"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"


.







(
B17
)







Here, we used ai−√{square root over (pi)}≤√{square root over (p)}|{tilde over (v)}i|−√{square root over (pi)}≤ε′/3.


We've shown that |ãi−ai|≤ε′+εtsp+|bi| for all cases. Therefore,














a
~

-
a



2
2





i


[



(


ε


+

ε
tsp


)

2

+

2




"\[LeftBracketingBar]"


b
i



"\[RightBracketingBar]"




(


ε


+

ε
tsp


)


+

b
i
2


]






(
B18
)













L

(


ε


+

ε
tsp


)

2

+

2


(


ε


+

ε
tsp


)




L




i


b
i
2





+



i


b
i
2










=


(



L



(


ε


+

ε
tsp


)


+




i


b
i
2




)

2


,






and


hence















a
~

-


p


ν




2








a
~

-
a



2

+




a
-


p


ν




2






(
B19
)














L



(


ε


+

ε
tsp


)


+




i


b
i
2



+




i



(



pv
i


-

a
i


)

2















L



(


ε


+

ε
tsp


)


+



2

p




ε
QLSP




,




where we used Σi ((vi−ai/√{square root over (p)})2+bi2/p)≤εQLSP2. Since {tilde over (v)}′∝ã, for some proportionality factor λ we have ∥λ{tilde over (v)}′−v∥√{square root over (2L)}(ε′+εtsp)+√{square root over (2)}εQLSP, where we used p≤½. A bit of geometry will show that if












c
-
d



2


γ
<

1


and





d


2



=
1

,



then







c



c


2


-
d



2






(
γ
)




2


sin



(


1
2



sin

-
1



γ

)



=



1
+
γ


-



1
-
γ


.







Applying this with c=λ{tilde over (v)}′ and d=v we obtain
















v
~



-
ν



2

+


(




2

L




ε
tsp


+


2



ε
QLSP



)



dg
dx




x
=




2

L




(


ε


+

ε
tsp


)


+


2



ε
QLSP







<


ε
+

1.
5

8


L



ε
tsp


+

1.58

ε
QLSP







(
B20
)







as claimed. In the second inequality we used the convexity of g; in the third inequality we used the fact that g(√{square root over (2L)}ε′)=ε, √{square root over (2L)}(ε′+εtsp)+√{square root over (2)}εQLSP<ε+√{square root over (2)}εtsp+E√{square root over (2)}εQLSP≤½, and √{square root over (2)}g′(½)<1.58.


Additional Information C: Null Space Matrix for Portfolio Optimization

In section III C, an inexact-feasible interior point method was described that uses as input a matrix B with columns that form a basis for the null space of the feasibility equations for the self-dual SOCP that appear in eq. (19). A straightforward way to find such a B in general may be to perform a QR decomposition of the constraint matrix, costing classical O(N3) runtime (or, using techniques for fast matrix multiplication, between O(N2) and O(N3) time). The upshot is that B can only be computed once and does not change with each iteration of the algorithm, but depending on other parameters of the problem, this classical runtime may dominate the overall complexity. Alternatively, in many specific cases including ours, a valid matrix B can be determined by inspection. For example, suppose that we have a (N−K)×N matrix QA with full column rank for which AQA=0, a K×(K−1) matrix P with full column rank for which bTP=0, and a point x0 for which Ax0=b. Then, letting γ=bTb/∥b∥2, a valid choice for B is









B
=




x




y




τ




θ




s




κ





(



0



Q
A



e



x
0





P




b
¯






c
¯





Q
A






b
¯



2







-


(

r
+
1

)





b
¯



2





b
¯










c
¯





x
0


-

z
¯






b
¯



2




b
¯






0


0


1


1




0


0


1


0






-

A




P





-

A





b
¯






c
¯





Q
A






b
¯



2









(

r
+
1

)





b
¯



2




A




b
¯


+
e









-


c
¯






x
0


+

z
¯






b
¯



2




A




b
¯


+
c







b



P






(

γ
-
1

)



c




Q
A


-

γ


e




Q
A






1
-

γ

(

r
+
1

)







-
γ



z
¯



(

r
+
1

)



c




x
0


-

γ


e




x
0






)






(
C1
)







The leftmost column in the above block matrix corresponds to K−1 basis vectors formed by choosing y to be a vector perpendicular to b and x=0, τ=θ=0. The second column corresponds to N−K vectors formed by choosing x to be in the null space of A, and letting τ=θ=0, with






y
=





c
¯




x





b
¯



2





b
¯

.






The third column corresponds to the vector formed by choosing x=e, τ=θ=1, and then






y
=



-

(

r
+
1

)






b
¯



2





b
¯

.






The final column corresponds to choosing x=x0, τ=1, θ=0, and






y
=






c
¯





x
0


-

z
¯






b
¯



2





b
¯

.






In each case, the choices of x, y, τ, and θ uniquely determine the values of s and κ. Note that in practice the second and fourth block rows of B can be ignored because in eq. (22) they are left-multiplied by a matrix whose second and fourth block columns are zero.


What remains is to specify P, QA, and x0 for the case of portfolio optimization, given in eq. (10). Finding a valid matrix P is straightforward. Note that from eq. (10), we have b=(1; w+ζ; w−ζ; 0). For j=1, . . . , 2n, let pj have a 1 in its first entry, and a−1/bj+1 in its (j+1)th entry, with zeros elsewhere. For j=2n+1, . . . , 2n+m, let pj have a single 1 in its (j+1)th entry, and zeros elsewhere. Thus, the pj are independent and bTpj=0 for all j. Then define the matrix P by P=(p1, . . . , p2n+m). Similarly, the columns of a valid matrix QA can be generated as follows: given a choice of w such that 1Tw=0, choose ϕ=−w, ρ=w, t=0, and η=Mw. As there are n−1 linearly independent choices of w (e.g. the vectors (1; −1; 0; 0; . . . ; 0), (0; 1; −1; 0; . . . ; 0), (0; 0; 1; −1; . . . ; 0), etc.), this leads to n−1 linearly independent columns of QA. A final nth column can be formed by choosing t=1 and w=ϕ=ρ=0 and η=0. Next, the point x0 can be chosen by letting w=w, =ρ=ζ, t=0, and η=Mw.


Additional Information D: Alternative Search Directions

The solution (Δx; Δy; Δτ; Δθ; Δs; Δκ) to the Newton systems in eqs. (19) and (22) is one possible search direction for the interior point method. Alternative search directions can be found by applying a scale transformation to the convex set. For the k-dimensional second-order cone custom-character, define the set










𝒢
k

=


{



λ

T

:

λ

>
0

,




T



(



1


0




0



-
I




)



T

=


(



1


0




0



-
I




)



}

.





(
D1
)







For the product custom-character of multiple cones, let the set custom-character include of direct sums of entries from custom-character. This definition implies that the matrices G∈custom-character map the set custom-character onto itself. Thus for a fixed choice G∈custom-character, consider a change of variables x′=GTx, s′=G−1s, y′=y. Let X′ and S′ be the arrowhead matrices for x′ and s′, and, following the same logic as above, the following Newton system is arrived at:











(





S




G
T




0


0


0




X




G

-
1





0




0


0


κ


0


0


τ



)




(




Δ

x






Δ

y






Δ

τ






Δ

θ






Δ

s






Δ

κ




)


=


(





σ

μ

e

-


X




S



e








σ

μ

-

κ

τ





)

.





(
D2
)







The solution to this linear set of equations (along with the feasibility equations of eq. (19)) is distinct for different choices of G. The choice G=I recovers eq. (22) and is called the Alizadeh-Haeberly-Overton (AHO) direction. Note that the IPM can reduce the duality gap by a constant factor after O(√{square root over (r)}) iterations for any choice of G. However, some choices of G can yield additional potentially desirable properties; for example, the Nesterov-Todd search direction scales the cone such that x′=s′. However, in the numerical simulations of the QIPM, no obvious benefits of choosing a search direction were observed other than the AHO direction.


Additional Information E: Numerical Results for Feasible QIPMs

Section VI presented numerical results for the “II-QIPM,” for which intermediate points could be infeasible. Here we also present some results for two variants of the “feasible” QIPM, denoted by “IF-QIPM” and “IF-QIPM-QR,” as summarized in table II. The IF-QIPM uses the null space basis B outlined in Additional Information C, whereas the IF-QIPM-QR version uses a null space basis B determined using a QR decomposition. In all cases, the algorithm was simulated for enough iterations to reduce the duality gap to 10−3, whereas for the II-QIPM it was simulated down to 10−7.


In FIGS. 13 to 15, the analogous results for the feasible IPMs are presented as were displayed in FIGS. 9 to 11 for the infeasible case. The IF-QIPM-QR has the best performance, though this should be weighed against the fact that an expensive QR decomposition was classically pre-computed to implement this method. However, the advantage of the IF-QIPM-QR method is not large enough for any of the qualitative conclusions in section VII to change. The IF-QIPM method has the worst performance, which may be due to the fact that the null-space basis found by inspection turns out to be a very ill-conditioned matrix (its condition number was observed to be in the vicinity of 1000). Additionally, the IF-QIPM appears to have the largest instance-to-instance variation of any of the methods, leading to lower quality numerical fits.



FIG. 13 includes two plots of the Median Frobenius condition number for 128 randomly sampled stock portfolios from the DWCF index as a function of portfolio size for duality gaps of 1.0, 0.1, 0.01, and 0.001. The error bars show the 68th percentile, which corresponds to one standard deviation if the distribution is Gaussian. A linear trend appears to work quite well for the IF-QIPM-QR case, but the IF-QIPM is quite noisy. For each duality gap, a power-law fit of the form anb is also ploted. The values of b are in table XII.



FIG. 14 includes two plots of the Median value of the square of the required inverse tomography precision used to remain in the neighborhood of the central path for 128 randomly sampled stock portfolios from the DWCF index as a function of portfolio size for duality gaps of 1.0, 0.1, 0.01, and 0.001. The error bars show the 68th percentile, which corresponds to one standard deviation if the distribution is Gaussian. For each duality gap, a linear fit on the log-log data is also plotted. The corresponding slope is in table XIII.



FIG. 15 includes two plots of the Median value of the estimated algorithm scaling factor computed as the median of n1.5κF2 for 128 randomly sampled stock portfolios from the DWCF index as a function of portfolio size for duality gaps of 1.0, 0.1, 0.01, and 0.001. The error bars show the 68th percentile, which corresponds to one standard deviation if the distribution is Gaussian. For each duality gap, a linear fit on the log-log data is also ploted. The corresponding slope is in table XIV.


TABLE XII sjpws fit parameters for the Frobenius condition number for the four horizontal-axis locations considered on the scaling plot of FIG. 13. The uncertainties correspond to one standard deviation errors on the parameter estimates from the fit. We note that both versions have similar empirical scaling, although the fits are better for IF-QIPM-QR. The constant prefactors are superior for the IF-QIPM-QR version, but calculating the QR decomposition requires a one-time classical cost proportional to custom-character(L3).


TABLE XIII shows fit parameters for the square of the inverse of the required tomography precision to stay near the central path, corresponding to FIG. 14. The uncertainties correspond to one standard deviation errors on the parameter estimates from the fit.


TABLE XIV shows estimated scaling of the quantum algorithm as a function of portfolio size for the two feasible versions of the quantum algorithm, corresponding to FIG. 15. The uncertainties correspond to one standard deviation errors on the parameter estimates from the fit.











TABLE XII





Dual. Gap
IF-QIPM
IF-QIPM-QR

















1.0
κF (G)~n0.57±0.60
κF (G)~n0.228±0.002


0.1
κF (G)~n0.58±0.28
κF (G)~n0.66±0.03


0.01
κF (G)~n0.81±0.53
κF (G)~n0.73±0.03


0.001
κF (G)~n1.01±0.77
κF (G)~n0.98±0.04


















TABLE XIII





Dual. Gap
IF-QIPM
IF-QIPM-QR

















1.0
ξ−2~ custom-character  (n−0.01±0.02)
ξ−2~ custom-character  (n−0.11±0.07)


0.1
ξ−2~ custom-character  (n−0.99±0.41)
ξ−2~ custom-character  (n−0.46±0.11)


0.01
ξ−2~ custom-character  (n0.53±0.91)
ξ−2~ custom-character  (n0.89±0.15)


0.001
ξ−2~ custom-character  (n0.93±0.66)
ξ−2~ custom-character  (n0.90±0.15)


















TABLE XIV





Dual. Gap
IF-QIPM
IF-QIPM-QR

















1.0

custom-character  (n1.41±0.01)


custom-character  (n2.07±0.15)



0.1

custom-character  (n1.23±0.40)


custom-character  (n1.77±0.15)



0.01

custom-character  (n2.87±0.91)


custom-character  (n3.13±0.18)



0.001

custom-character  (n3.54±0.64)


custom-character  (n3.50±0.10)










The above sections describe example embodiments for purposes of illustration only. Any features that are described as essential, necessessary, required, 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.


Additionally, the above sections often use the phrase “we” (and other similar phases) to reference an entity that is performing an operation (e.g., a step in an algorithm). These phrases are used for convenience. These phrases may refer to a computing system (e.g., computing system 1700) that is performing the described operations.


IX. EXAMPLE METHODS


FIG. 16 is a flowchart of an example method 1600, specifically a quantum interior point method (QIPM), for solving a second-order cone program (SOCP) instance using a quantum computing system, according to one or more embodiments. As previously described, a QIPM includes one or more quantum operations that provide a computational advantage over other methods of solving SOCP instances. Specifically, the algorithmic complexity for the quantum method can be better (in some ways) than the classical method. The classical method scales as n3.5 log (1/∈) and the quantum algorithm scales as n1.5kF log (1/∈)/ξ2.


In the example of FIG. 16, the method 1600 is performed from the perspective of a computing system (e.g., 1700) including a quantum computing system (e.g., 1720). The method 1600 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 1600 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 1600. Algorithm 1 is an example of method 1600. In some embodiments, one or more steps of the method can be used to determine solutions for optimization problems other than a SOCP.


At step 1610, the computing system receives the SOCP instance (e.g., see input of Algorithm 1). The SOCP instance may include quantities (A, b, c) as described with respect to eq. 10. The computing system may also receive a list of cone sizes (N1, . . . , Nr) and a tolerance ∈ (also referred to as precision ∈). In some embodiments, computing system receives the SOCP instance with N>0 variables, K>0 linear constraints, r>0 second-order cone constraints, and the tolerance parameter E, where matrix A of the SOCP instance is a K×N matrix encoding linear constraints, vector b is a length-K vector encoding right-hand side of linear constraints, and vector c is a length-Nvector encoding an (e.g., objective) function (e.g., see eq. (5)).


At step 1620, the computing system defines a Newton system for the SOCP instance by constructing matrix G and vector h (e.g., steps 4 and 5 of Algorithm 1). Matrix G and vector h describe constrains for a linear system Gu=h based on the SOCP instance. Defining the system in this way enables the benefits of the quantum approach over classical approaches to be realized.


At step 1630, the computing system preconditiones matrix G and vector h via row normalization to reduce a condition number of matrix G (e.g., steps 6-10 of Algorithm 1). Among other advantages, preconditioning matrix G and vector h reduces their computational complexity (due to the reduced condition number), which reduces computational time.


Preconditioning matrix G and vector h may include determining a diagonal matrix D where at least one (e.g., each or every) entry Dii is equal to the norm of row i of matrix G. After determining the the matrix D, matrix G and vector h may be redefined according to: G=D−1G and h=D−1h, where D−1G has a condition number less that the condition number of previous/original matrix G. More information on preconditioning can be found above at, for example, sections I B and V A.


At step 1640, the computing system iteratively determines u until a predetermined iteration condition is met. For example, see steps 13-18 of Algorithm 1, where in this context u is (x′; y′; τ′; θ′; s′; custom-character) and the predetermine iteration condition is (x′; y′; τ′; θ′; s′; custom-character) ∈custom-character(γ)). The iterations may include:


The iterations of step 1640 may include causing the quantum computing system to apply matrix G and vector h to a quantum linear system solver (QLSS) to generate a quantum state (e.g., part of step 15 of Algorithm 1). Causing the quantum computing system to apply matrix G and vector h to the QLSS to generate the quantum state may include k>0 applications of the QLSS and k controlled-applications of the QLSS to generate the quantum state. Causing the quantum computing system to apply matrix G and vector h to the QLSS may include causing the quantum computing system to execute a quantum circuit. More information on the QLSS can be found above at, for example, section IV B.


The QLSS may operate on a block encoded version of matrix G and a state-prepared version of vector h. To do this, the method 1600 may include causing matrix G to be block encoded onto the quantum computing system and the vector h to be state encoded onto the quantum computing system. As previously described, block-encodings enable quantum algorithms (the QLSS in this case) to coherently access classical data (G and h in this case). More information on block encoding can be found above at, for example, sections I B and IV C.


The interations of step 1640 may include causing the quantum computing system to perform quantum state tomography on the quantum state (e.g., part of step 15 (e.g., step 27) of Algorithm 1). Causing the quantum computing system to perform quantum state tomography may include causing the quantum computing system to execute a quantum circuit. Conceptually, the quantum state tomography “reads out” the results of calculations “stored” in the quantum state.


The output of the of the quantum state tomography may be a unit vector {tilde over (v)}′ indicating an iteration direction for u (e.g., {tilde over (v)}′ is (Δx; Δy; Δτ; Δθ; Δs; Δcustom-character) of Algorithm 1). The unit vector {tilde over (v)}′ may be characterized by ∥{tilde over (v)}′−v∥≤ξ with probability equal to or greater than a predetermined probability threshold (e.g., probability at least 1−δ, where δ is, for example, 0.1), where v∝G−1h and ξ is a tomography precision parameter (e.g., see steps 24 and 28 of Algorithm 1).


In some embodiments, the quantum state tomography is performed according to a tomography precision parameter ξ that decreases with each new iteration (e.g., see ξ in Algorithm 1). The tomography precision parameter ξ may decrease by ξ/2 with each new iteration (see e.g., step 14 of Algorithm 1). More information on quantum tomography can be found above at, for example, sections IV D and V A.


The interations of step 1640 may include updating a value of u based on a current value of u and the output of the quantum state tomography (e.g., steps 16-17 of Algorithm 1). For example, updating the value of u may include determining an updated step length σ≠0 based on the unit vector {tilde over (v)}′, and adding the current value of u to the product of: (1) the updated step length σ and (2) the unit vector {tilde over (v)}′ (e.g., see steps 16-17 of Algorithm 1, where “step length” refers to the updated step length, σ refers to the current step length, the current value of u is (x; y; τ; θ; s; custom-character), and the updated value of u is (x′; y′; τ′; θ′; s′; custom-character). As used herein, a value of a vector (e.g., u or {tilde over (v)}′) may refer to the value of a single component or of multiple components of that vector.


In some embodiments, the updated step length σ is given by by:








μ

(

x
,
τ
,
s
,

)



(

1
-
σ

)



(

r
+
1

)





-


(

Δ

x

)





s

-



(

Δ

s

)




x

-

(

Δ
,


τ

-


(
Δτ
)










where Δx, Δs, Δcustom-character, and Δτ are components of the unit vector {tilde over (v)}′; x, s, custom-character, and τ are components of current u; μ(x, τ, s, custom-character) is a duality gap; σ is the current step length; and r is the number of second-order cone constraints of the SOCP instance. The updated step length may be determined such that a duality gap μ of the updated value of u is a factor of σ (the current step length) smaller than the current value of u within a second order deviation in the step length σ. The duality gap μ may describe a difference between the current value of u and an exact solution to the linear system Gu=h. More information on step length can be found above at, for example, sections I B, V A, and IV A.


At step 1650, the computing system determines a solution to the SOCP instance based on the updated value of u (e.g., steps 19-21 of Algorithm 1). In the example of Algorithm 1, the solution to the SOCP instance (within precision ∈) is vector x of (x; y; τ; θ; s; custom-character)).


In some embodiments, steps 1620-1640 are repeated iteratively (e.g., see loop of steps 3-21 of Algorithm 1). For example, a target precision F for the solution to the SOCP instance is received (referred to as “tolerance” or “precision” in Algorithm 1), and steps 1620-1640 are repeated and a duality gap μ is iteratively updated based on the output of the quantum state tomography (e.g., the new duality gap μ is the product of current duality gap μ and the updated step length σ (e.g., see also step 20 of Algorithm 1) until the duality gap μ is less than the target precision F (e.g., see condition at step 3 of Algorithm 1), where the duality gap μ describes a difference between the current value of u and an exact solution to the linear system Gu=h. In these embodiments, matrix G and vector h may be constructed (in step 1620) further based on the (e.g., updated) value of u (e.g., u is (x; y; τ; θ; s; custom-character) and G and h depend at least on one of these quantities in steps 4 and 5 of Algorithm 1).


X. DESCRIPTION OF A COMPUTING SYSTEM

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



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


The classical computing system 1710 may operate or control the quantum computing system 1720. For example, the classical computing system 1710 causes the quantum computing system 1720 to perform one or more operations, such as to execute a quantum algorithm or quantum circuit (e.g., the classical computing system 1710 generates and transmits instructions for the quantum computing system 1720 to execute a quantum algorithm or quantum circuit). For example, the computing system 1710 causes the quantum computing system 1720 to perform one or more steps of method 1600. Although only one classical computing system 1710 is illustrated in FIG. 17A, any number of classical computing system 1710 or other external systems may be connected to the quantum computing system 1720.



FIG. 17C is a block diagram that illustrates the quantum computing system 1720, according to some embodiments. The quantum computing system 1720 includes any number of quantum bits (“qubits”) 1750 and associated qubit controllers 1740. As illustrated in FIG. 17D, the qubits 1750 may be in a qubit register 1755 of the quantum computing system 1720 (or multiple registers). Qubits are further described below. A qubit controller 1740 is a module that controls one or more qubits 1750. A qubit controller 1740 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 1740 may perform physical operations on one or more qubits 1750 (e.g., it can perform quantum gate operations on a qubit 1740). In the example of FIG. 17C, a separate qubit controller 1740 is illustrated for each qubit 1750, however a qubit controller 1740 may control multiple (e.g., all) qubits 1750 of the quantum computing system 1720 or multiple controllers 1740 may control a single qubit. For example, the qubit controllers 1740 can be separate processors, parallel threads on the same processor, or some combination of both.



FIG. 17E is a flow chart that illustrates an example execution of a quantum routine on the computing system 1700. The classical computing system 1710 generates 1760 a quantum program to be executed or processed by the quantum computing system 1720. The quantum program may include instructions or subroutines to be performed by the quantum computing system 1720. In an example, the quantum program is a quantum circuit. The quantum computing system 1720 executes 1765 the program and computes 1770 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 1720 that resulted from executing the program. Practically, this may be performed by measuring values of one or more of the qubits 1750. The quantum computing system 1720 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 1775 by the classical computing system 1710. Results may be returned after a termination condition is met (e.g., a threshold number of shots occur). The classical computing system 1710 may determine a quantity based on the received results.


The quantum computing system 1720 exploits the laws of quantum mechanics in order to perform computations. A quantum processing device, a quantum computer, a quantum processor system, and a quantum processing unit (QPU) are each examples of a quantum computing system. The quantum computing system 1700 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 1700 is a gate model quantum computer. As previously described, quantum computing systems use so-called qubits, or quantum bits (e.g., 1750A). While a classical bit 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). Additionally, the disclosure is not specific to qubits. The disclosure may be generalized to apply to quantum computing systems 1720 whose building blocks are qudits (d-level quantum systems, where d>2) or quantum continuous variables, rather than qubits.


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 unitary operation performed on one or more qubits. 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. 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 1740) 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. 18 is an example architecture of a classical computing system 1710, according to some embodiments. The quantum computing system 1720 may also have one or more components described with respect to FIG. 18. FIG. 18 depicts a high-level block diagram illustrating physical components of a computer system used as part or all of one or more entities described herein, in accordance with an embodiment. A computer may have additional, less, or variations of the components provided in FIG. 18. Although FIG. 18 depicts a computer 1800, the figure is intended as a functional description of the various features which may be present in computer systems rather than 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. 18 are at least one processor 1802 coupled to a chipset 1804. Also coupled to the chipset 1804 are a memory 1806, a storage device 1808, a keyboard 1810, a graphics adapter 1812, a pointing device 1814, and a network adapter 1816. A display 1818 is coupled to the graphics adapter 1812. In one embodiment, the functionality of the chipset 1804 is provided by a memory controller hub 1820 and an I/O hub 1822. In another embodiment, the memory 1806 is coupled directly to the processor 1802 instead of the chipset 1804. In some embodiments, the computer 1800 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 1808 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, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Such a storage device 1808 can also be referred to as persistent memory. The pointing device 1814 may be a mouse, track ball, or other type of pointing device, and is used in combination with the keyboard 1810 to input data into the computer 1800. The graphics adapter 1812 displays images and other information on display 1818. The network adapter 1816 couples the computer 1800 to a local or wide area network.


The memory 1806 holds instructions and data used by the processor 1802. The memory 1806 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 1800 can have different or other components than those shown in FIG. 18. In addition, the computer 1800 can lack certain illustrated components. In one embodiment, a computer 1800 acting as a server may lack a keyboard 1810, pointing device 1814, graphics adapter 1812, or display 1818. Moreover, the storage device 1808 can be local or remote from the computer 1800 (such as embodied within a storage area network (SAN)).


As is known in the art, the computer 1800 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 storage device 1808, loaded into the memory 1806, and executed, individually or together, by one or more processors (e.g., 1802).


XI. ADDITIONAL CONSIDERATIONS

Some portions of the 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 quantum interior point method (QIPM) for solving a second-order cone program (SOCP) instance using a quantum computing system, the method comprising: (a) receiving the SOCP instance;(b) defining a Newton system for the SOCP instance by constructing matrix G and vector h, where matrix G and vector h describe constrains for a linear system Gu=h based on the SOCP instance;(c) preconditioning matrix G and vector h via row normalization to reduce a condition number of matrix G;(d) iteratively determining u until a predetermined iteration condition is met, the iterations comprising: causing the quantum computing system to apply matrix G and vector h to a quantum linear system solver (QLSS) to generate a quantum state;causing the quantum computing system to perform quantum state tomography on the quantum state; andupdating a value of u based on a current value of u and the output of the quantum state tomography; and(e) determining a solution to the SOCP instance based on the updated value of u.
  • 2. The method of claim 1, wherein preconditioning matrix G and vector h comprises: determining a diagonal matrix D where at least one entry Dii is equal to the norm of row i of matrix G.
  • 3. The method of claim 2, further comprising redefining matrix G and vector h according to: G=D−1G and h=D−1h.
  • 4. The method of claim 3, wherein D−1G has a condition number less that the condition number of previous matrix G.
  • 5. The method of claim 1, wherein the output of the quantum state tomography is a unit vector {tilde over (v)}′ indicating an iteration direction for u.
  • 6. The method of claim 5, wherein the unit vector {tilde over (v)}′ is characterized by ∥{tilde over (v)}′−v∥≤ξ with probability equal to or greater than a predetermined probability threshold, where v∝G−1h and ξ is a tomography precision parameter.
  • 7. The method of claim 5, wherein updating the value of u comprises: determining a step length σ≠0 based on the unit vector {tilde over (v)}′; andadding the current value of u to the product of: (1) the step length σ and (2) the unit vector {tilde over (v)}′.
  • 8. The method of claim 7, wherein the step length is given by:
  • 9. The method of claim 7, wherein the step length σ is determined such that a duality gap μ of the updated value of u is a factor of σ smaller than the current value of u within a second order deviation in the step length σ.
  • 10. The method of claim 9, wherein the duality gap μ describes a difference between the current value of u and an exact solution to the linear system Gu=h.
  • 11. The method of claim 1, wherein the quantum state tomography is performed according to a tomography precision parameter ξ that decreases with each new iteration.
  • 12. The method of claim 11, wherein the tomography precision parameter ξ decreases by ξ/2 with each new iteration.
  • 13. The method of claim 1, wherein causing the quantum computing system to apply matrix G and vector h to the QLSS to generate the quantum state comprises k>0 applications of the QLSS and k controlled-applications of the QLSS to generate the quantum state.
  • 14. The method of claim 1, further comprising: receiving a target precision F for the solution to the SOCP instance; andrepeating steps (b)-(d) and iteratively updating a duality gap μ based on the output of the quantum state tomography until the duality gap μ is less than the target precision ε, where the duality gap μ describes a difference between the current value of u and an exact solution to the linear system Gu=h.
  • 15. The method of claim 14, wherein matrix G and vector h are constructed further based on the updated value of u.
  • 16. The method of claim 1, wherein causing the quantum computing system to apply matrix G and vector h to the QLSS comprises causing the quantum computing system to execute a quantum circuit.
  • 17. The method of claim 1, wherein the QLSS operates on a block encoded version of matrix G and a state-prepared version of vector h.
  • 18. The method of claim 17, further comprising: causing matrix G to be block encoded onto the quantum computing system and the vector h to be state encoded onto the quantum computing system.
  • 19. A non-transitory computer-readable storage medium storing code that, when executed by a computing system including a quantum computing system, causes the computing system to perform operations comprising: receiving a second-order cone program (SOCP) instance;defining a Newton system for the SOCP instance by constructing matrix G and vector h, where matrix G and vector h describe constrains for a linear system Gu=h based on the SOCP instance;preconditioning matrix G and vector h via row normalization to reduce a condition number of matrix G;iteratively determining u until a predetermined iteration condition is met, the iterations comprising: causing the quantum computing system to apply matrix G and vector h to a quantum linear system solver (QLSS) to generate a quantum state;causing the quantum computing system to perform quantum state tomography on the quantum state; andupdating a value of u based on a current value of u and the output of the quantum state tomography; anddetermining a solution to the SOCP instance based on the updated value of u.
  • 20. The non-transitory computer-readable storage medium of claim 19, wherein preconditioning matrix G and vector h comprises: determining a diagonal matrix D where at least one entry Dii is equal to the norm of row i of matrix G.
CROSS-REFERENCE TO RELATED APPLICATION

This application claims priority to U.S. Provisional Patent Application Ser. No. 63/413,230, “End-to End Analysis for Quantum Interior Point Methods with Improved Block-Encodings,” filed on Oct. 4, 2022, which is incorporated herein by reference in its entirety.

Provisional Applications (1)
Number Date Country
63413230 Oct 2022 US