This disclosure relates generally to controlling quantum computing systems, and more particularly, to controlling quantum computing systems to determine quantities of objects.
Quantum computing systems can be controlled to determine quantities of objects with stochastic behaviors (e.g., pricing of financial derivatives) using Amplitude Estimation (AE). These control methods may provide a quadratic speedup compared to traditional classical Monte Carlo methods. However, the estimated resources required for the quantum circuits of these control methods are considerably higher than what is possible with current and near-term quantum computing devices. Thus, there is a desire to determine new control methods that use fewer quantum resources.
Embodiments of the disclosure have other advantages and features which will be more readily apparent from the following detailed description and the appended claims, when taken in conjunction with the examples in the accompanying drawings, in which:
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.
This disclosure describes controlling quantum computing systems to determine quantities of objects (e.g., quantities that change stochastically). These new techniques use fewer quantum computational resources than conventional techniques. Among other advantages, these new techniques may reduce computational resources by determining quantum operators that enable use of Quantum Signal Processing (QSP) techniques to determine the quantity of an object (e.g., the value of a product). For ease of explanation, the below descriptions describe controlling quantum computing systems in the context of determining pricing for financial derivatives. However, embodiments are not limited to this example use case. For example, the techniques described herein can also be used to control quantum computing systems to determine initial states for differential equations, quantum simulations of field theories and finite element analysis.
In a quantum setting, the quantum circuits which drive the pricing process of a financial derivate may include two components: 1) loading the probability distribution over paths of the stochastic variables involved in the calculation and 2) encoding the payoff of each path into the amplitude of an ancilla qubit. The first component can be represented by an operator (also “P”) which, given stochastic paths ω∈Ω where each path occurs with probability p(ω), it prepares a probability-weighted superposition of all paths
The second component is an operator which computes the discounted payoff ƒ(ω) of the derivative on each path |ω, and encodes that value in the amplitude of an ancilla qubit
The operator =
creates a state such that the probability of measuring |0 in the last qubit is the price of the derivative, represented as the expected value of the discounted payoff, [ƒ]=Σω∈Ωp(ω)ƒ(ω) (which may be determined by performing amplitude estimation).
However, the implementation of the operator in Eq. (2) requires binary quantum arithmetic to compute a digital representation of the payoff |ƒ(ω) from a path |ω, before that value is encoded into the amplitude of the last qubit (use of “last,” “final” or “target” to refer to a qubit herein is used for merely for convenience to reference a specific qubit. A “last,” “final” or “target” qubit is not required to be last or final relative to other qubits (e.g., it is not required to be the last or final qubit on a quantum register)). In order to avoid the costly quantum arithmetic of this process, this disclosure shows (among other things) how to determine a quantum operator U+{right arrow over (ϕ)} (alternative to ) using Quantum Signal Processing to generate a quantum state with the value √{square root over (ƒ(ω))} directly in the amplitude of an ancilla qubit, which significantly reduces the total resources used. More specifically, this disclosure enables preparation of the following state:
Given an n-bit register |xn, and a unitary quantum operator U which creates the state (note that ω from the previous descriptions is replaced with x)
where |ψ0n and |ψ1n are normalized quantum states, the goal is to generate a unitary quantum operator U+{right arrow over (ϕ)} that prepares the state
for normalized quantum states |ψ0′n, |ψ1′n, and |0⊥a denoting a normalized state orthogonal to |0a. A, B, C are constants such that (Aex−B)/C∈[0,1]. To prepare the unitary quantum operator of Eqn. (5), aspects from Quantum Signal Processing may be used as further described below. Quantum Signal Processing is also generally described below in the section titled “Quantum Signal Processing.”
Defining projectors {tilde over (Π)}≡⊗2n⊗|00| and Π≡⊗n⊗(00|)⊗n+1, observe that {tilde over (Π)}UΠ is a rank-1 matrix with a single non-trivial singular value √{square root over (x)}. Consecutive invocations of U and U†, interleaved with projector-controlled rotation operators Πϕ= and {tilde over (Π)}ϕ=, enables applications of polynomial transformations to this singular value, using the Quantum Signal Processing framework. Given phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd), define
Then, for any polynomial G satisfying deg(G)≤d, |G(a)|≤1, ∀a∈[−1,1], and G either even or odd, there exist phase factors {right arrow over (ϕ)} such that the unitary
creates the state
With an appropriately chosen polynomial G which approximately performs
the unitary U+{right arrow over (ϕ)} can be used to approximately prepare the target state in Eq. (5). A circuit description of the operator U+{right arrow over (ϕ)} is shown in
This section shows how to implement the unitary U of Eq. (4) and the choice of polynomial G used in Eq. (9) in order to construct the target state Eq. (5). This section assumes that the register |x is an n-bit, binary, fixed-point representation of a scalar x with p digits to the left of the binary point
First consider the case where x is positive with p=0, such that x<1
where xi∈0, 1 denotes the i-th bit of |x and N=2n. The first step to implement the transformation of Eq. (5) is to encode the value √{square root over (x)} to the amplitude of an ancilla qubit. Start with the state |x and apply Hadamard gates to n ancilla qubits to generate a uniform superposition:
Then apply the following unitary operator
to perform a binary comparison2 between the two qubit registers of Eq. (12), which produces the state 2An example for implementing the comparator operator can be found at: T. G. Draper, S. A. Kutin, E. M. Rains, and K. M. Svore, “A logarithmic-depth quantum carry-lookahead adder,” Quantum Information and Computation 6, 351 (2006). Link: https://arxiv.org/abs/quant-ph/0406142
with x given by Eq. (11). The probability of measuring |0 in the comparator ancilla qubit is then
The unitary U=(⊗H⊗n⊗) acting on the state |x|0 therefore creates the target state of Eq. (4)
where |ψ0 and |ψ1 n are normalized quantum states which depend on the value of x. A polynomial G which approximates the function
in the domain x∈[0,1] allows approximate preparation of the target state given by Eq. (5) using Eq. (9).
When p>0 such that x≥1 (see Eqn. (10)), the unitary U as above may be used, ignoring the location of the binary point p, which in this case generates the state
Because of the extra factor of 2p, the polynomial G in this case approximates the function
in order to generate the target state of Eq. (5).
In order to handle negative values of x, first pick a value s≥|x|≥0 and then apply a binary addition circuit which performs |x|0→|x|x+s, where |x+s is again a fixed-point register with m total digits and p to the left of the binary point (thus increasing the x values to all be zero or positive). The unitary U of Eq. (17) is then applied with the second register as input to construct the state
where the normalization factor 2p arising from treating the fixed-point register |x+s as a binary string in the comparator circuit, similarly handles the case x≤−1.0. The polynomial G which generates the target state of Eq. (5) approximates the function
Note that for both positive and negative values of x, the transformation in Eq. (19) guarantees that the input to the polynomial G will only be the domain x∈[0,1]. This way, while only polynomials with definite parity (either even or odd) can be implemented using Quantum Signal Processing, the function being approximated with Quantum Signal Processing can be extended to the domain x∈[−1,1] using ƒ(−x)=ƒ(x) or ƒ(−x)=−ƒ(x), even if ƒ(x) does not have definite parity. Additionally, the unitary U of Eq. (19) and the function Eq. (20) allow construction of the target state for any input x, provided that ƒ(x)∈[0, 1].
This section describes how the descriptions in the previous sections to prepare the state in Eq. (5) can be used in derivative pricing to compute example payoffs of the form ƒ(S)=max(0, S−K), by considering a European call option. Given a strike price K, the holder of a European call option contract receives at a future date T (the expiration date) the amount
where ST is the market price of an underlying asset (which is an example of an object) at date T. In order to determine the value of this contract today, the future price of the underlying asset is modeled as a stochastic variable with an appropriate probability distribution, and the price of the option is calculated by computing the expectation value of its payoff in Eq. (21).
An example re-parameterization method for derivative pricing3 implements the operator of Eq. (1) by loading a discretized normal distribution and then performing an affine transformation to the registers using quantum arithmetic to generate a superposition of possible log-returns ri at time T, each weighed by the probability of occurrence 3For more details, see: S. Chakrabarti, R. Krishnakumar, G. Mazzola, N. Stamatopoulos, S. Woerner, and W. J. Zeng. “A Threshold for Quantum Advantage in Derivative Pricing,” Quantum 5, 463 (2021). Link: https://quantum-journal.org/papers/q-2021-06-01-463/
where N=2n. In this example, the price of the underlying asset for each possible log-return ri is then given by Si=S0er
computing the payoff of Eq. (21)
and finally encoding the payoff into the amplitude of an ancilla qubit
where ƒmax=emax{r
which is the expectation value of the option's payoff, normalized by ƒmax. Thus, applying amplitude estimation to the last qubit estimates the price of the option.
However, the above example re-parameterization method requires explicit computation of the values |Si=S0er
Let the |ri register of Eq. (22) represent each log-return in fixed-point representation and let s=ln(S0/K). Apply a circuit which performs the comparison |riρ|0→|ri|ri≤s to Eq. (22) to get
Add an m-qubit register and compute |riρ|0→|ri|ri+|s|, where the second register is also a fixed-point representation and m is large enough to hold the maximum value of ri+|s|, to get
where terms with the last qubit being in the |1 state are ignored. Note that 0≤ri+|s|<2p if the register |ri+|s| has p digits to the left of the binary point. The application of the U operator of Eq. (19) to the |ri+|s| register and a new qubit register |0 gives
for normalized quantum states |ψ0 and |ψ1. Employing the Quantum Signal Processing unitary U+{right arrow over (ϕ)} of Eq. (9) with phases {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) chosen such that the polynomial G approximates the function
produces
with |B=|0 for odd d, and
with |B=|0 for even d, where terms with any qubit in the last register being in the |1 state are ignored. Applying amplitude estimation to estimate the probability of measuring the |B state gives
which is the same as the value estimated using the example re-parameterization method in Eq. (26). However, among other advantages, the method of equations 27-33 does not use quantum arithmetic to explicitly compute the values of |Si=S0er
Although previous descriptions provide examples methods for controlling a quantum computing system to determine the value of an object (e.g., determining the price of a financial derivative), the below paragraphs describe additional examples. The descriptions below may omit steps previously described and/or include steps that are in addition to or alternative to the steps previously described.
At step 310, the computing system receives a function ƒ(x) describing a value of an object (which is an example of a quantity of the object), values of x, and probabilities p(x) for the values of x.
At step 320, the computing system receives (or determines) a quantum operator P (also “”) that, when executed by a first quantum computing system (e.g., 420), creates a first quantum state characterized by a superposition of states encoding the x values, where the amplitude for a corresponding x value is the square root of the probability p(x) for that x value. The first quantum state may be a probability weighted superposition for all the values of x. For example, the first quantum state is given by Σx√{square root over (p(x))}|x, where |x is a quantum state on an n-qubit register storing an n-bit binary representation of the corresponding value of x. For additional information on the quantum operator P, see e.g., Eqns. (1) and (22) and associated descriptions (note that in Eqn. (1), the symbol ω is used instead of x).
At step 330, the computing system determines a quantum operator U+{right arrow over (ϕ)} (e.g., see Eqn. (9) and associated description) that, when executed by a quantum computing system (e.g., 420 or another quantum computing system), encodes an approximation of the function ƒ(x) in an amplitude of a second quantum state without calculating |ƒ(x) for any of the values of x(|ƒ(x) is a binary representation of an output value of ƒ(x) stored on qubits of a quantum register). Note that U+{right arrow over (ϕ)} in
Steps 310, 320, and 330 may be part of example step 460 in
At step 340, the computing system controls (e.g., instructs) a third quantum computing system (e.g., 420 or another quantum computing system) to execute both of the quantum operators P and U+{right arrow over (ϕ)} to generate a third quantum state on a register of qubits. One of the amplitudes of the third quantum state includes probabilities p(x) for the values of x and output values of the function ƒ(x) for the values of x. Instructing the third quantum computing system to execute both of the quantum operators P and U+{right arrow over (ϕ)} includes instructing the third quantum computing system to execute the quantum operator P prior to executing the quantum operator U+{right arrow over (ϕ)}.
In some aspects, the one of the amplitudes of the third quantum state is the square root of the weighted average of ƒ(x) for the x values where the weights are the probabilities p(x) for the corresponding values of x. Said differently, the one of the amplitudes is Σx√{square root over (p(x))}√{square root over (ƒ(x))} (which means the probability of measuring the state associated with the one of the amplitudes is [ƒ]=Σxp(x)ƒ(x)).
Step 340 may be part of example step 465 in
At step 350, the computing system determines the value of the object based on the generated third quantum state.
Step 350 may be part of example step 475 in
In some aspects, the method 300 does not include calculating |ƒ(x).
In some aspects, the method 300 further includes determining s, where s is based on the absolute values of the x values; and instructing the third quantum computing system to apply a quantum binary addition circuit that performs the operation: |x|0→|x|x+s, where n and m are integers greater than zero, m>n, |x is a quantum state on an n-qubit register storing an n-bit binary representation of a value of x, and |x+s is a quantum state on an m-qubit register storing a representation of a value of x+s with m total digits and p digits to the left of the binary point. In some aspects, s is based on the upper bound of the absolute values of the x values (e.g., s≥|x|≥0). For example, s is the absolute value of the smallest x value of the values of x (however, s may be larger than this). For example, if the x values range from 4 to −5, then s=5.
In some aspects, the quantum binary addition circuit is executed subsequent to execution of the quantum operator P but prior to execution of the quantum operator U+{right arrow over (ϕ)}.
For additional information on s and the quantum binary addition circuit, see e.g., Eqns. (18)-(19) and (27)-(29) and their associated descriptions.
In some aspects, determining the quantum operator U+{right arrow over (ϕ)}, includes generating an if initial quantum operator given by U=C(⊗H⊗m⊗), where C is a comparator quantum circuit defined by C:|a|b|0→|a|b|a<b, I is an identity matrix, and H is a Hadamard gate. For more information on the initial quantum operator U, see Eqns. (10)-(15) and their associated descriptions.
In some aspects, determining the quantum operator U+{right arrow over (ϕ)} further includes applying the initial quantum operator U to state |x+s|0 to generate the following quantum state:
are normalized quantum states. For more information, see Eqn. (4)-(5) and (15)-(19) and their associated descriptions.
In some aspects, determining the quantum operator U+{right arrow over (ϕ)} includes performing a Quantum Signal Processing (QSP) algorithm. Performing the QSP algorithm may include determining phase parameters representing a polynomial approximation that approximates
where A, B, and C are constants: (1) based on the function ƒ(x) and (2) that satisfy
For more information, see Eqns. (20) and (3) and their associated descriptions. The approximation error of the polynomial approximation may be within a target error threshold of the target function (which in this case is
In general, to decrease the approximation error, the degree of the polynomial is increased, which increases the computational resources to perform the calculation. Thus, the error of the polynomial approximation may be based on the available resources and the error target threshold for the value of the object being determined.
In some aspects, the function ƒ(x) is a normalized function with output values ranging from zero to one.
In some aspects, the value (an example of a quantity of the object) of the object fluctuates stochastically.
In some aspects, determining the value of the object based on the generated quantum state includes performing an amplitude estimation algorithm to determine value of the object.
Some aspects relate to new example method including: instructing (e.g., by a classical computing system 410) a quantum computing system (e.g., 420) to execute a quantum operator that prepares an approximation to a target quantum state given by:
where x is a scalar number; |x is a quantum state on an n-qubit register of the quantum computing system storing an n-bit binary representation of x; n and a are integers greater than zero; |ψ0′ and |ψ0′ are normalized quantum states; |0⊥ is a normalized quantum state orthogonal to |0; A, B, and C are constants such that (Aex−B)/C∈[0, 1]; and the approximation is within an error threshold of
In some aspects, the quantum computing system executes the quantum operator on a register of qubits.
Other aspects include components, devices, systems, improvements, methods, processes, applications, computer readable mediums, and other technologies related to any of the above.
This section provides a general description of Quantum Signal Processing (QSP). QSP is a technique which performs polynomial transformations to the singular values of a matrix A that has been block-encoded into a unitary operator. Specifically, given projectors Π and {tilde over (Π)}, a unitary U acting on n qubits is a block-encoding of a matrix A if A={tilde over (┌)}UΠ, such that the projectors Π and {tilde over (Π)} determine the location of A in U
QSP includes consecutive applications of U and U†, interleaved with projector-controlled rotation operators Πϕ= and {tilde over (Π)}ϕ=, which for phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) induce a polynomial transformation on A such that
where σk denote the singular values of A while {|wk}, {|vk} are the left and right singular vectors of A respectively, and G is a d-degree polynomial. When A is Hermitian, in which case the singular values of the matrix coincide with its eigenvalues, Quantum Signal Processing effectively performs a polynomial transformation to the eigenvalues of the matrix.
More formally, define the operators
If U is an n-qubit unitary, the polynomial transformation achieved through QSP is implemented with
where Π′={tilde over (Π)} for odd d and {tilde over (Π)}′=Π for even d.
In practice, d invocations of U perform a d-degree polynomial transformation to A and the choice of phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) determine the exact polynomial that is applied. Remarkably, the reverse is also true: for a∈[−1, 1] and any real polynomial G∈(a), there exists a sequence of QSP phase factors {right arrow over (ϕ)}=(ϕ1, ϕ2, . . . , ϕd) for which Eqn. (38) holds, as long as deg(G)≤d, |P(a)|≤1, ∀a∈[−1, 1], and G either even or odd. Additionally, for any function ƒ(a) satisfying these conditions a polynomial approximation to the function can be identified, the QSP phase factors {right arrow over (ϕ)} for that polynomial can be determined, and QSP used to approximately apply ƒ(a) to the singular values of the block-encoded matrix. Various methods have been proposed to generate polynomial approximations to generic functions, where the approximation is either constructed analytically or with optimization-based numerical methods.
Embodiments described above may be implemented using one or more computing systems. Example computing systems are described below.
The classical computing system 410 may control the quantum computing system 420. For example, the classical computing system 410 generates and transmits instructions for the quantum computing system 420 to execute a quantum algorithm or quantum circuit. Although only one classical computing system 410 is illustrated in
The quantum computing system 420 exploits the laws of quantum mechanics in order to perform computations. A quantum processing device (QPU), a quantum computer, a quantum processor system, and a quantum processing unit are each examples of a quantum computing system. The quantum computing system 420 can be a universal or a non-universal quantum computing system (a universal quantum computing system can execute any possible quantum circuit (subject to the constraint that the circuit doesn't use more qubits than the quantum computing system)). In some embodiments, the quantum computing system 420 is a gate model quantum computer. As previously described, quantum computing systems use so-called qubits, or quantum bits (e.g., 450A). While a classical bit always has a value of either 0 or 1, a qubit is a quantum mechanical system that can have a value of 0, 1, or a superposition of both values. Example physical implementations of qubits include superconducting qubits, spin qubits, trapped ions, arrays of neutral atoms, and photonic systems (e.g., photons in waveguides). For the purposes of this disclosure, a qubit may be realized by a single physical qubit or as an error-protected logical qubit that itself comprises multiple physical qubits. Additionally, the disclosure is not specific to qubits. The disclosure may be generalized to apply to quantum computing systems 420 whose building blocks are qudits (d-level quantum systems, where d>2) or quantum continuous variables, rather than qubits.
A quantum operator (e.g., U+{right arrow over (ϕ)} or P) may be one or more quantum circuits. A quantum circuit is an ordered collection of one or more gates. A sub-circuit may refer to a circuit that is a part of a larger circuit. A gate represents a physical unitary operation performed on one or more qubits (e.g., changing the state of a qubit from 0 to 1 or creating a superposition of 0 and 1). Quantum gates may be described using unitary matrices. The depth of a quantum circuit is the least number of steps used to execute the circuit on a quantum computing system (e.g., 420). The depth of a quantum circuit may be smaller than the total number of gates because gates acting on non-overlapping subsets of qubits may be executed in parallel. A layer of a quantum circuit may refer to a step of the circuit, during which multiple gates may be executed in parallel. In some embodiments, a quantum circuit is executed by a quantum computing system. In this sense, a quantum circuit can be thought of as comprising a set of instructions or operations that a quantum computing system can execute. To execute a quantum circuit on a quantum computing system, a user may inform the quantum computing system what circuit is to be executed. A quantum computing system may include both a core quantum device and a classical peripheral/control device (e.g., a qubit controller 440) that is used to orchestrate the control of the quantum device. It is to this classical control device that the description of a quantum circuit may be sent when one seeks to have a quantum computer execute a circuit.
The parameters of a parameterized quantum circuit may refer to parameters of the gates. For example, a gate that performs a rotation about the y axis may be parameterized by a real number that describes the angle of the rotation.
The description of a quantum circuit to be executed on one or more quantum computing systems may be stored in a non-transitory computer-readable storage medium. The term “computer-readable storage medium” should be taken to include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) able to store instructions. The term “computer-readable medium” shall also be taken to include any medium that is capable of storing instructions for execution by the quantum computing system and that cause the quantum computing system to perform any one or more of the methodologies disclosed herein. The term “computer-readable medium” includes, but is not limited to, data repositories in the form of solid-state memories, optical media, and magnetic media.
Illustrated in
The storage device 508 is any non-transitory computer-readable storage medium, such as a hard drive, compact disk read-only memory (CD-ROM), DVD, or a solid-state memory device or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, magnetic disk storage devices, optical disk storage devices, flash memory devices, or other non-volatile solid state storage devices. Such a storage device 508 can also be referred to as persistent memory. The pointing device 514 may be a mouse, track ball, or other type of pointing device, and is used in combination with the keyboard 510 to input data into the computer 500. The graphics adapter 512 displays images and other information on the display 518. The network adapter 516 couples the computer 500 to a local or wide area network.
The memory 506 holds instructions and data used by the processor 502. The memory 506 can be non-persistent memory, examples of which include high-speed random access memory, such as DRAM, SRAM, DDR RAM, ROM, EEPROM, flash memory.
As is known in the art, a computer 500 can have different or other components than those shown in
As is known in the art, the computer 500 is adapted to execute computer program modules for providing functionality described herein. As used herein, the term “module” refers to computer program logic utilized to provide the specified functionality. Thus, a module can be implemented in hardware, firmware, or software. In one embodiment, program modules are stored on the storage device 508, loaded into the memory 506, and executed, individually or together, by one or more processors (e.g., 502).
The disclosure above describes example embodiments for purposes of illustration only. Any features that are described as essential, important, or otherwise implied to be required should be interpreted as only being required for that embodiment and are not necessarily included in other embodiments.
Some portions of above disclosure describe the embodiments in terms of algorithmic processes or operations. These algorithmic descriptions and representations are commonly used by those skilled in the computing arts to convey the substance of their work effectively to others skilled in the art. These operations, while described functionally, computationally, or logically, are understood to be implemented by computer programs comprising instructions for execution, individually or together, by one or more processors, equivalent electrical circuits, microcodes, or the like. Furthermore, it has also proven convenient at times, to refer to these arrangements of functional operations as modules, without loss of generality. In some cases, a module can be implemented in hardware, firmware, or software.
As used herein, any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment. Similarly, use of “a” or “an” preceding an element or component is done merely for convenience. This description should be understood to mean that one or more of the elements or components are present unless it is obvious that it is meant otherwise. As used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments. This is done merely for convenience and to give a general sense of the disclosure. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise. Where values are described as “approximate” or “substantially” (or their derivatives), such values should be construed as accurate +/−10% unless another meaning is apparent from the context. From example, “approximately ten” should be understood to mean “in a range from nine to eleven.”
Alternative embodiments are implemented in computer hardware, firmware, software, and/or combinations thereof. Implementations can be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a programmable processor system including one or more processors that can act individually or together; and method steps can be performed by a programmable processor system executing a program of instructions to perform functions by operating on input data and generating output. Embodiments can be implemented advantageously in one or more computer programs that are executable on a programmable system including one or more programmable processors coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. Each computer program can be implemented in a high-level procedural or object-oriented programming language, or in assembly or machine language if desired; and in any case, the language can be a compiled or interpreted language. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, a processor will receive instructions and data from a read-only memory and/or a random-access memory. Generally, a computer will include one or more mass storage devices for storing data files; such devices include magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and optical disks. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM disks. Any of the foregoing can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits) and other forms of hardware.
Although the above description contains many specifics, these should not be construed as limiting the scope of the disclosure but merely as illustrating different examples. It should be appreciated that the scope of the disclosure includes other embodiments not discussed in detail above. Various other modifications, changes, and variations which will be apparent to those skilled in the art may be made in the arrangement, operation, and details of the methods and apparatuses disclosed herein without departing from the spirit and scope of the disclosure.
Number | Date | Country | Kind |
---|---|---|---|
20230100473 | Jun 2023 | GR | national |
This application claims priority to, and the benefit of, U.S. Provisional Patent Application Ser. No. 63/522,277 “Derivative Pricing using Quantum Signal Processing” filed Jun. 21, 2023 and Greek patent application No. 20230100473 filed on Jun. 14, 2023, each of which are incorporated by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
63522277 | Jun 2023 | US |