This disclosure relates generally to quantum simulations, and more particularly, to simulating stochastic processes using quantum computing systems.
Oftentimes one wishes to simulate stochastic processes (e.g., to perform financial calculations). Examples include: modeling the price of securities or financial instruments fluctuating over time, the movement of interest rates, etc. This is a subroutine in many quantum computational finance algorithms.
The simulation of a stochastic process can have a particular form. In one example it is assumed that the stochastic process would be modeled as a quantum state of the form
Where traj denotes a price trajectory—for example, the value of the security at different times, and Pr[traj] denotes the probability of obtaining that price trajectory under that particular stochastic model. In this representation, the computational basis state of the quantum state in register A represents a price trajectory while the amplitude of the quantum state represents the probability of landing in that trajectory. This state might be entangled with another register B (which is labeled as “junk” as it does not play a role in algorithmic applications).
The state in the equation above is the sort of state one obtains by “quantizing” a classical randomized algorithm simulating a stochastic process. That is, if one has a classical randomized algorithm R simulating the price trajectory—which takes as input a random seed r and outputs a price trajectory with the appropriate probability—then preparing an equal superposition over random seeds r and (coherently) passing it through a reversible compilation of R yields a state of the desired form.
However, the above quantum stochastic process simulation subroutine may be difficult on a near-term quantum computing system, as one must run the classical simulation algorithm in superposition. This could be a bottleneck in the near-term applicability of quantum algorithms which use stochastic process simulation as a subroutine, such as quantum algorithms for Monte Carlo.
We have developed a new method to simulate stochastic processes on a quantum computing system. A stochastic process may be represented by a probability distribution over (e.g., random or semi-random) variables that can represent, for example, the value of a quantity fluctuating in time. This new simulation method can then be used as a subroutine in quantum algorithms, for example in quantum Monte Carlo algorithms to price derivatives and perform risk calculations. Our simulation method makes use of three points described below.
Point 1: A new way of representing a price trajectory as a quantum state in an inherently analogue fashion, where the price of the security at time t is stored in the amplitude of the quantum state rather than its computational basis state.
Point 2: A new application of a real version of the quantum Fourier transform, known as the discrete cosine transform (DCT). We use the DCT to transform this analogue state into its Fourier basis. In this basis oftentimes a stochastic process has a simpler representation, e.g. in the case of Ito processes such as Brownian motion and its generalizations.
Point 3: Using a quantum data loader (further described in U.S. patent application Ser. Nos. 16/986,553 and 16/987,235) to load the Fourier transform of the stochastic process. In particular we use the data loader recursively, first using the data loader algorithm to prepare a quantum state encoding a probability distribution over data loader angles which, when passed through the data loader, prepare the distribution on the DCT of the desired stochastic process. See
One can then use this representation as a subroutine in many quantum algorithms, for example quantum Monte Carlo algorithms to price derivatives.
Other aspects include components, devices, systems, improvements, methods, processes, applications, computer readable mediums, and other technologies related to any of the above.
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.
Point 1: create a quantum state which is a fundamentally different representation of the stochastic process. In our approach, the basis state of the quantum computing system in register A is the time, and the amplitude is a function of the price of the security at that time. In that way a single quantum state encodes a particular price trajectory
This is in some sense an analogue representation of a price trajectory. Here and throughout this document we suppress normalization factors, which we address later.
Such states can be used in quantum algorithms for a variety of financial instruments. For example, if f is trivial, then the inner product between |Ψtraj and an equal superposition over a subset of times is precisely the average value of the stock during that time period (up to normalization), so such states could be used in the quantum Monte Carlo pricing of Asian options, to give one example.
A stochastic process describes a probability distribution over such states |Ψtraj. Therefore in order to quantumly simulate a stochastic process in this form, we wish to prepare the mixed state:
Point 2: instead of preparing this state directly, the discrete cosine transform (DCT) of this state is prepared. The DCT is the real part of the Quantum Fourier Transform of a quantum state, and the discrete sine transform (DST) is its imaginary part. More formally, if the QFT on n qubits is defined as
QFTij=ωij,
where ω=e2πi/N where N=2{circumflex over ( )}n is the dimension of the Hilbert space then we have that
DCTij=cos(2πij/N)
which is a unitary matrix.
The DCT can be performed efficiently on a quantum computing system by modifying the standard algorithm for the QFT. In particular one can perform the DCT on 2n+1 qubits using O(nlog n) gates. This is because the DCT is the real part of the QFT, the QFT admits an algorithm with 2n qubits and O(nlogn) two-qubit gates, and there are methods to perform the real part of a complex quantum circuit using the same number of gates and one additional qubit (for an example method, see: Michael Nielsen and Isaac Chuang (2000). Quantum Computation and Quantum Information. Cambridge: Cambridge University Press.).
To prepare our desired state ρ to simulate the stochastic process, we instead prepare the state:
σ=DCT−1 ρ DCT
After preparing this state a, we then apply the DCT algorithm to obtain ρ, which is our quantum simulation of the stochastic process. Therefore, the only step remaining to be described in our method is to prepare the state σ or a close approximation thereof
We now note that by linearity, σ is the DCT of our stochastic process. For many stochastic processes used in finance, for example Ito processes, this DCT has an explicit mathematical description given in the mathematics literature. This is often used many places in computational finance. For example, if price(t) is governed by Brownian motion (more formally, a Brownian bridge which returns to the origin in time π), then if one writes:
price(t)=a0+a1cos(t)+a2 cos(2t)+a3 cos(3t)+. . .
Then Brownian motion is reproduced when ak is distributed as N(0,1)/k—i.e. as a Gaussian of unit variance divided by k. In other words, the DCT of Brownian motion is a vector of independent Gaussians of decreasing magnitude. For the rest of this section, we will refer back to this example frequently to illustrate our method.
Therefore, the next step of our method is to find the DCT of our desired stochastic process S analytically, which is may be found in the mathematical literature. Therefore, if price(t) is governed by S, this induces a probability distribution D over the coefficients a0, a1, a2 . . . .
The next step is to truncate this DCT series at a finite value of k>0. This omits high-frequency content from the stochastic process, which introduces a small amount of error in the simulation. Given a desired accuracy level of simulation (say 1% error), the value of k can be set by the user accordingly to achieve that error. For most cases of practical interest setting e.g. k=100 suffices. We approximate σ, the true DCT of the stochastic process, using this kth order truncation, call it σ′.
Therefore our problem reduces to: given a number k (the truncation parameter) and a description of the probability distribution D over the DCT coefficients a0, a1, a2 . . . ak, prepare a quantum state σ′ encoding this distribution D. In other words, we wish to create a probability distribution over quantum states |ν whose first k+1 amplitudes are a0, a1, a2 . . . ak, and the rest of the amplitudes are zero, and the probability that we prepare |ν is specified by the distribution D. In quantum notation, we prepare the following density matrix: ν′=Eν˜Dνν|. For example, in the case of Brownian motion, our goal is to load a vector of independent Gaussians of length k of decreasing variance.
We now describe our Point 3, which is to use a quantum data loader to prepare ν′—which is (e.g., approximately) the DCT of our stochastic process. Applying the DCT to the state ν′ will prepare the state ρ′, which is approximately our stochastic process.
The quantum data loader is an algorithm A which prepares generic quantum states. The algorithm takes as input quantum registers containing various real angles θi as well as an initial state |0n. It then prepares a quantum state |φ(θi). In other words, A |θi|0n|θi|φ)θi) (quantum data loaders are also described U.S. patent application Ser. Nos. 16/986,553 and 16/987,235, which are incorporated herein).
Therefore for each vector ν=a0, a1, a2 . . . ak of length k we wish to load, there is a corresponding setting of the angles θi(ν) which cause |φ(θi)=|ν. In other words, θi(ν) is the inverse of the data loader map taking angles to vectors.
The probability distribution D induces a distribution D′ on angles θi through this inverse map. In other words, D′ is the distribution on data loader angles θi for which, if we draw θi from the distribution D′ and prepare the state |φ(θi) using the data loader with θi as the inputs, then this prepares the same density matrix σ′ as obtained by drawing ν from D and preparing the state |ν. More formally,
σ′=Eθ
For example, suppose D is a distribution of length k independent identically distributed N(0,1) Gaussian entries. Then one can explicitly compute D′—in particular, one can prove the distribution D′ on the θi may all be independent in the binary data loader algorithm, and the distribution of the angle θ at the jth level of the data loader tree is given by the probability density function cosj(θ)sinj(θ).
The point of the algorithm is to “data load the dataloader,” i.e. to apply the data loader algorithm A twice in series in order to prepare σ′. The data loader may be applied with different angles each time.
That is, we first use the data loading algorithm A to load a quantum state |D′ which, upon measurement, yields the probability distribution D′. In other words, create the state:
|D′=Σ√{square root over (Pr(θi))}|θi.
This is performed using our analytical description of D′ to find angles |φ for which A|φi|0n=|φi|D′. Note that D′ in
We then apply the data loader algorithm A using |D′ as the input to the θi register. One can then see that tracing out the first register of A |D′|0n yields the state σ′ as desired. This completes the algorithm and its proof of correctness.
In certain cases, like Brownian motion, there are additional ways to create this state σ′. For example, to simulate Brownian motion, first prepare a state
of independent identically distributed N(0,1) Gaussians by the above recipe, i.e. ignore the decay in the norm of the Gaussian entries in the Brownian motion's DCT. (As discussed above this state may be easy to prepare as the corresponding distribution D′ on angles is a product distribution (i.e. is independent) over the different angles.). We then perform the following algorithm to “add back in” the decay of norms: create the state
using the data loader. Now given |K|ν, compute the difference of the two registers, producing the state
Since the αk+jmodN are still independent Gaussians, (as the independent Gaussian distribution is invariant under permuting entries) the amplitudes of this state are distributed as independent Gaussians divided by a normalization factor, and this therefore prepares the state σ′ corresponding to Brownian motion as desired.
Next, we discuss how one deals with the normalization of the vectors involved (e.g., all vectors involved in the algorithm). In the above description we assumed the price trajectories are of unit norm when expressed as analogue vectors |Ψtraj. But this may not be the case for certain stochastic processes. To correct for this, we use concentration of measure to argue that for typical price trajectories in stochastic processes, the norms of the trajectories (or equivalently, the norms of the Fourier series) are highly concentrated. We then therefore fix a normalization factor N in advance, assume the norm of the price trajectories is less than this normalization factor, and ignore the rare trajectories where the stochastic process violates this norm condition. The value of the normalization factor N can be set according to the user's desired level of accuracy.
We now succinctly summarize the method as follows. The method may be performed by a computing system (e.g., including a classical computing system and a quantum computing system). See
Begin with the stochastic process of price trajectories one wishes to model—e.g., the distribution on functions price(t).
Analytically take the DCT of this stochastic process. This is established for many stochastic processes in the mathematics literature, for example the DCT of Brownian motion is given by its Wiener series. This gives a probability distribution on the DCT coefficients a0, a1, a2, . . . of the stochastic process.
Truncate the DCT series at a finite value of k.
Analytically compute the inverse map to determine the distribution of data loader angles D′ which, after passing through the data loader A, creates this truncated DCT series.
Using a classical computing system, compute the data loader angles |φi which load the classical probability D′ as a quantum state.
Execute the quantum algorithm to prepare the state ρ′ (an approximation to ρ) as follows in Steps A-C:
Step A: Run the data loader A on |φ to produce the state |D′
Step B: Run the data loader A again on |D′ to produce the state σ′, which by construction is a close approximation to σ.
Step C: Apply the DCT algorithm to σ′ to produce ρ′, a close approximation to ρ (e.g., within a threshold error or percentage (e.g., if k=200 for Brownian motion, the error is 0.3 per cent.)).
In some embodiments, the last steps (Steps A-C) are run on the quantum computing system. The other steps may be pre-computations performed analytically, once per each stochastic process one wishes to model.
The computing system receives 310 a stochastic process with a plurality of trajectories over time t.
The computing system determines 320 a first quantum circuit that, when executed by a quantum computing system, prepares a mixed quantum state ρ′ in the quantum computing system, where ρ′ approximates a mixed quantum state of the stochastic process and is defined by:
where Pr[traj] is a probability of a trajectory of the stochastic process, |ψtraj is a quantum state representing a trajectory of the stochastic process and is defined by
where ƒ(t) is based on a value of the stochastic process at time t. In some embodiments, the method of claim 1, wherein |ψtraj represents the trajectory of the stochastic process overall all possible times t.
In some embodiments, determining the first quantum circuit comprises: determining a discrete cosine transform (DCT) series of the stochastic process; determining a probability distribution for coefficients in the DCT series; and determining a probability distribution of angles D′, the probability distribution of angles D′ being parameter values for a first data loader quantum circuit that is configured to, when executed by the quantum computing system, generate a mixed quantum state σ′ corresponding to a vector of the coefficients in the DCT series. The determined discrete cosine transform (DCT) series may be truncated to have a finite number of coefficients (the number of coefficients is greater than zero). In some embodiments, determining the probability distribution for coefficients in the DCT series comprises determining a probability distribution for each coefficient in the DCT series. Determining the first quantum circuit may further include: determining sets of parameter values for a set of data loader quantum circuits configured to, when executed by the quantum computing system, generate a quantum state |D′ representing the probability distribution over the angles (quantum state |D′ may be used by a data loader circuit for generated the quantum representation of the DCT series). In some embodiments, the computing system executes the first quantum circuit to generate the mixed quantum state ρ′. Executing the first quantum circuit may include: executing the set of data loader quantum circuits to generate the quantum state |D′; applying the first data loader quantum circuit to the quantum state D′ to generate the mixed quantum state σ′; and applying a DCT quantum circuit to the mixed quantum state σ′ to generate the mixed quantum state ρ′.
The quantum computing system 420 executes 465 the program and computes 470 a result (referred to as a shot or run). Computing the result may include performing a measurement of a quantum state generated by the quantum computing system 420 that resulted from executing the program. Practically, this may be performed by measuring values of one or more of the qubits 450. The quantum computing system 420 typically performs multiple shots to accumulate statistics from probabilistic execution. The number of shots and any changes that occur between shots (e.g., parameter changes)) may be referred to as a schedule. The schedule may be specified by the program. The result (or accumulated results) is recorded 475 by the classical computing system 410. Results may be returned after a termination condition is met (e.g., a threshold number of shots occur).
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 computing system 500. The graphics adapter 512 displays images and other information on the display 518. The network adapter 516 couples the computing system 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 computing system 500 can have different or other components than those shown in
As is known in the art, the computing system 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 by the processor 302.
Referring back to
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 needed 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) 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 computing system execute a circuit.
A variational quantum circuit may refer to a parameterized quantum circuit that is executed many times, where each time some of the parameter values may be varied. The parameters of a parameterized quantum circuit may refer to parameters of the gate unitary matrices. 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. Variational quantum algorithms are a class of hybrid quantum-classical algorithm in which a classical computing system is used to choose and vary the parameters of a variational quantum circuit. Typically, the classical processor updates the variational parameters based on the outcomes of measurements of previous executions of the parameterized circuit.
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.
The approaches described above may be amenable to a cloud quantum computing system, where quantum computing is provided as a shared service to separate users. One example is described in patent application Ser. No. 15/446,973, “Quantum Computing as a Service,” which is incorporated herein by reference.
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.
Additionally, the above disclosure often uses 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., including a classical computing system and a quantum computing system) that is performing the described operations.
Some portions of above description 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 by a processor or equivalent electrical circuits, microcode, 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; and method steps can be performed by a programmable processor executing a program of instructions to perform functions by operating on input data and generating output. As used herein, ‘processor’ may refer to one or more processors. Embodiments can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor 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 invention 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 invention.
This application claims priority under 35 U.S.C. § 119(e) to U.S. Provisional Patent Application Ser. No. 63/295,409 “A Method For Simulating Stochastic Processes With A Quantum Computer,” filed on Dec. 30, 2021, the subject matter of which is incorporated herein by reference in their entirety.
Number | Name | Date | Kind |
---|---|---|---|
20190392340 | Leipold et al. | Dec 2019 | A1 |
Entry |
---|
Ghafari et al. Interfering Trajectories In Experimental Quantum-Enhanced Stochastic Simulation Nature Communications, 2019 (Year: 2019). |
Blank et al. Quantum-Enhanced Analysis of Discrete Stochastic Processes, Nature Partner Journals, Aug. 9, 2021 (Year: 2021). |
Blank, C., et al., “Quantum-enhanced analysis of discrete stochastic processes,” npj Quantum Information, vol. 7, Article No. 126, 2021, pp. 1-9. |
Chakrabarti, S., et al., “A Threshold for Quantum Advantage in Derivative Pricing,” Quantum, vol. 5, 463, 2021, pp. 1-41. |
Cherubini, U., et al., Fourier Transform Methods in Finance, vol. 524. John Wiley & Sons, 2010. |
Egger, D.J., et al., “Credit Risk Analysis Using Quantum Computers,” arXiv:1907.03044, 2019, pp. 1-8. |
Ghafari, F., et al., “Interfering trajectories in experimental quantum-enhanced stochastic simulation,” Nature Communications, vol. 10, Article No. 1630, 2019, pp. 1-8. |
International Search Report and Written Opinion, Patent Cooperation Treaty Application No. PCT/US2022/037168, dated Nov. 16, 2022, 15 pages. |
Montanaro, A., “Quantum speedup of Monte Carlo methods,” Proceedings of the Royal Society A: Mathematical, Physical and Engineering Sciences, Sep. 2015, vol. 471, Issue 2181, pp. 1-20. |
Nielsen and Chuang, Quantum Computation and Quantum Information, 2000, Cambridge: Cambridge University Press. |
Rebentrost, P., et al., “Quantum computational finance: Monte Carlo pricing of financial derivatives,” Physical Review A, vol. 98, Iss. 2, Aug. 2018, arXiv:1805.00109, pp. 1-17. |
Wiener, N., “Differential-space,” Journal of Mathematics and Physics, vol. 2, Issue 1-4, Oct. 1923, pp. 131-174. |
Woerner, S. et al., “Quantum risk analysis,” npj Quantum Information, vol. 5, Article No. 15, 2019, pp. 1-8. |
Number | Date | Country | |
---|---|---|---|
20230214699 A1 | Jul 2023 | US |
Number | Date | Country | |
---|---|---|---|
63295409 | Dec 2021 | US |