Wireless mobile communication technology uses various standards and protocols to transmit data between a base transceiver station (BTS) and a wireless mobile device. Some wireless devices communicate using an orthogonal frequency-division multiplexing (OFDM) digital modulation scheme via a physical layer. OFDM standards and protocols can include the third generation partnership project (3GPP) long term evolution (LTE), the Institute of Electrical and Electronics Engineers (IEEE) 802.16 standard (e.g., 802.16e, 802.16m), which is commonly known to industry groups as WiMax (Worldwide interoperability for Microwave Access), and the IEEE 802.11 standard, which is commonly known to industry groups as WiFi. In LTE systems, the BTS can be a combination of evolved Node Bs (also commonly denoted as enhanced Node Bs, eNode Bs, or eNBs) and Radio Network Controllers (RNCs) in a Universal Terrestrial Radio Access Network (UTRAN), which communicates with the wireless mobile device, known as a user equipment (UE). Both the BTS and wireless mobile device can transmit and receive data. The transmitting station (Transmitter or Tx) can transmit data via a signal on a channel to a receiving station (Receiver or Rx), where a channel uses a specified frequency bandwidth. The transmitted signal on the channel from the transmitter can vary from the received signal at the receiver due to noise and interference. Estimating the effects of the channel in an OFDM signal can improve data transmission between wireless devices.
Features and advantages of the disclosure will be apparent from the detailed description which follows, taken in conjunction with the accompanying drawings, which together illustrate, by way of example, features of the disclosure; and, wherein:
Reference will now be made to the exemplary embodiments illustrated, and specific language will be used herein to describe the same. It will nevertheless be understood that no limitation of the scope of the invention is thereby intended.
Before the present invention is disclosed and described, it is to be understood that this invention is not limited to the particular structures, process steps, or materials disclosed herein, but is extended to equivalents thereof as would be recognized by those ordinarily skilled in the relevant arts. It should also be understood that terminology employed herein is used for the purpose of describing particular examples only and is not intended to be limiting. The same reference numerals in different drawings represent the same element. Numbers provided in flow charts and processes are provided for clarity in illustrating steps and operations and do not necessarily indicate a particular order or sequence. The term matrix and vector may be used interchangeably. A matrix (plural matrices) can be a rectangular array of numbers, symbols, or expressions. A vector (or vector space) can be a mathematical structure formed by a collection of vectors: objects that may be added together and multiplied (“scaled”) by numbers, called scalars.
An initial overview of technology embodiments is provided below and then specific technology embodiments are described in further detail later. This initial summary is intended to aid readers in understanding the technology more quickly but is not intended to identify key features or essential features of the technology nor is it intended to limit the scope of the claimed subject matter.
Data in wireless mobile communication can be transmitted on the physical (PHY) layer by the transmitting station (Transmitter or Tx) to the receiving station (Receiver or Rx) using a generic long term evolution (LTE) frame structure, as illustrated in
In the example illustrated in
Reference signals can be transmitted by OFDM symbols via resource elements in the resource blocks. Reference signals (or pilot signals or tones) can be a known signal used to estimate a channel and/or noise in the channel. As illustrated in
A wireless communication system can be subdivided into various sections referred to as layers. In the LTE system, communication layers can include the physical (PHY), media access control (MAC), radio link control (RLC), packet data convergence protocol (PDCP), and radio resource control (RRC) layers. The physical layer can include the basic hardware transmission components of a wireless communication system 400, as illustrated in
The transmitted channel 450 signal can be subject to noise 452 and interference. The noise and interference is represented as an addition 454 to the channel signal, which can be received by a receiver antenna 490 and a radio frequency (RF) receiver (Rx) 482 at the receiver 460. The channel signal combined with the noise and interference can be converted to a digital modulated signal with an analog-to-digital converter (ADC) 480. The digital signal can be OFDM demodulated using a demodulator 478. The demodulator can use a fast Fourier transform (FFT) algorithm to compute the discrete Fourier transform (DFT) to generate a demodulated signal (vector y). A channel estimator 462 and/or noise estimation filter 464 can use the demodulated signal to estimate the noise and interference that occurs in the channel 450 and provide noise estimation, respectively. The demodulated signal can be demapped using a demapper 476, deinterleaved using a deinterleaver 474, and decoded by a channel decoder 472 to generate binary output data 470 that can be used by other layers of the receiving station.
The channel estimator 462 may be used to estimate the original channel in an OFDM transmission. The noise estimation filter 464 can be used to estimate the noise level of noise associated with an OFDM channel. The estimated noise level can be used as an input for a channel quality indicator (CQI) report, a precoding matrix indicator (PMI) report, a transmission rank indicator (RI) report, and other feedback reports. The estimated noise level can also be used in interference mitigation and spatial whitening of the OFDM signal.
In channel estimation, as illustrated in
Channel and noise estimation using a channel estimator can have a significant signal “leakage” into the noise estimate, thus in high signal-to-interference and noise ratio (SINR) conditions, the estimate from the channel estimator described in
An OFDM system can be equivalent to a transmission of data over a set of parallel channels. As a result, the fading channel of an OFDM system can be viewed as a two dimensional lattice in a time-frequency plane.
The filter bank of U coefficients 550 can multiply a unitary vector by the reference signal vector y to generate scalar products (vector z) 540 of the reference signal vector y. Single estimates 542 of the scalar products can be generated by taking the square of the absolute values 552 of the scalar products of the vector z. The single estimates can be multiplied 556 by D coefficients 554 (pre-computed combining coefficients) to generate multiple weighted single estimates 544. The D coefficients will be discussed in greater detail in the discussion that follows. The weighted single estimates can be summed 558 together to obtain an estimate for the interference and noise power 546.
The reference signal vector y 510 can be a vector of reference signals with a length of n numbers of reference signals, wherein n is a positive integer. The unitary vector and D coefficients can be pre-computed (computed prior to the reception of the reference signal vector y). The filter bank of U coefficients or unitary vector can be an Eigen vector matrix of a channel covariance matrix. The channel covariance matrix can be based on a generalized channel model, channel statistics, and/or other assumptions. The channel statistics can be generated based on long-term statistics, so a recalculation of the unitary vector and D coefficients occurs infrequently. The D coefficients can be optimized by generating normalized combining coefficients that can minimize the sum of distortion (bias) caused by the signal and variance of the estimator. In one embodiment, Lagrange multipliers can be used to optimize the D coefficients. The D coefficients can be noise coefficients, which can be a positive constant represented by
when
otherwise the noise coefficient can have a zero value.
In Expression 1, the variable i represents a reference signal 1 to n where n is a positive integer, λ is a Lagrange multiplier, dhh,i is an Eigenvalue of a channel covariance matrix Λhh, and δ2 is the variance of the noise. A sum of the plurality of noise coefficients can have a value of one to provide a plurality of normalized noise coefficients. The Lagrange multiplier λ can have a value
where dhh,j and dhh,k each represent at least one Eigenvalue for the channel covariance matrix where j and k are positive integers in the set 1 to n.
Mathematically, a D coefficient {tilde over (d)}i can be represented by
where di={tilde over (d)}i for {tilde over (d)}i>0, di=0 for {tilde over (d)}i≦0, and
A strong reference signal can be assumed to have little or no noise contribution to the received channel, which corresponds to the y vector. The strong reference signal can have a noise coefficient with a value of substantially zero. The coefficient multiplication module 582 can store a plurality of noise coefficients and at least one of the plurality of noise coefficients may have a value of zero. The sum of the plurality of noise coefficients stored in the coefficient multiplication module can have a value of one to provide a plurality of normalized noise coefficients.
In another example (not shown), after the filter banks coefficients (U coefficients) and noise coefficients (D coefficients) are pre-calculated (before receiving a reference signal), a matrix A can be constructed where A=U·D·U*, where ( )* is a conjugate transpose of the vector. The noise estimation can then be generated by δ2 where δ2=y*·A·y.
In one embodiment, the D coefficients can be determined using a “water-pouring” method, as illustrated in
where i represents reference signal 1 to n where n is a positive integer, dhh,i is an Eigenvalue of a channel covariance matrix Λhh, and δ2 is the variance of the noise. The total “power” of the estimated power level is limited by a value of one. The water fill level is a consti·di, where
i represents a reference signal 1 to n, where n is a positive integer, dhh,i is an Eigenvalue of a channel covariance matrix Λhh, and δ2 is the variance of the noise. The value di can be determined. The value of di can be proportional to the constant floor value
Another example provides a method 700 for estimating noise in an orthogonal frequency-division multiplexed (OFDM) signal, as shown in the flow chart in
The noise estimation filter and the method for estimating noise in an orthogonal frequency-division multiplexed (OFDM) signal can be used in a SISO wireless network (one transmitter antenna transmits each pilot tone or reference signal that can be received by one receiver antenna). A similar approach can be used for a SIMO wireless network (the pilot pattern or reference signal pattern transmitted from one transmitter antenna and received by at least two receiver antennas) or a MIMO wireless network (the pilot pattern or reference signal pattern transmitted from at least two transmitter antennas and received by at least two receiver antennas), where a quadratic estimator and a conjugate module is used. The noise estimation filter can be included in link adaption, interference mitigation, and/or a digital demodulator.
The noise estimation filter can provide noise estimation over a modulated signal and can provide a distinction between the noise and the modulated signal, after passing through an unknown channel. The estimation of noise can be based on Principal Component Analysis (PCA) of the reference (pilot) signal (i.e. decomposition of the signal into orthogonal components). A few PCA components can be used where the signal is weakest to estimate the noise and/or interference. The noise estimation filter and associated method can provide for a selection of combining of PCA components for a noise and/or interference estimation.
The noise estimation filter can use a quadratic estimator for noise and/or interference. Before a measurement time (a time at which reference signals are received), PCA components can be pre-computed as the Eigenvectors of an a priori channel covariance matrix at the reference signals locations. For each PCA component, a weight coefficient can also be pre-computed. A PCA component with non-zero weight can be referred to as a “noise filter” or simply a “filter”. The strong signal components may get zero coefficients. Thus strong signal components can be excluded from the noise estimation. The rest of the filters with a non-zero coefficient can form “the bank of noise filters.”
In the measurement time (when pilot signals are received), the method for estimating noise in an orthogonal frequency-division multiplexed (OFDM) signal can include the following stages. First, computing scalar products of the reference signal with all of the filters from the bank. Then, calculating “single estimates”, equal to the square of absolute values of the scalar products. And then, weighting the “single estimates” with pre-computed combining coefficients and summing the weighted “single estimates” together. Thus, an estimate for the interference plus noise power can be obtained.
The following discussion provides more details or term definitions and how the coefficients can be computed on the basis of an a priori channel covariance matrix (at pilot locations) Λhh, and on variance δ2, which can be a ratio of thermal noise to the signal power.
n is a number of reference signals being used for the estimation.
y is the reference signal vector.
Λhh=E[HH*] is an a priori channel covariance matrix at the reference symbols (RS) locations in the reference signal vector.
dhh,i for i=1, . . . , n is comprised of Eigenvalues of Λhh.
ai for i=1, . . . , n is comprised of Eigenvectors of Λhh (the noise filters).
di for i=1, . . . , n is comprised of combining coefficients.
Noise estimation coefficients can be derived using a generalized form of the noise estimation. The received pilots (or reference signals) can be represented by Equation 1, where h is a channel coefficient vector and v is a noise vector.
y=y+v [Equation 1]
A noise amplitude estimate can be represented by Equation 2, where {circumflex over (v)} is a vector of length N filters, y is a vector of length N pilots, and {tilde over (C)} is the noise estimation filters matrix of size N filters×N pilots. The noise estimation filters matrix {tilde over (C)} can be equivalent to (I-C)/Bias in a channel estimator (
{circumflex over (v)}={tilde over (C)}y [Equation 2]
A normalized noise estimate can be represented by Equation 3.
{circumflex over (σ)}2={circumflex over (v)}*·{circumflex over (v)}=y*{tilde over (C)}*{tilde over (C)}y [Equation 3]
The conjugate transpose of the noise estimation filters matrix {tilde over (C)}* and the noise estimation filters matrix {tilde over (C)} can be represented by A={tilde over (C)}*{tilde over (C)}. For this example, the noise estimation filter matrix can be the square root of A. Equivalently, the estimation can be represented by Equation 4.
{circumflex over (σ)}2=y*Ay [Equation 4]
To produce a real and positive estimation {circumflex over (σ)}2, the matrix A may be a positive (non-negative) definite matrix (i.e., the matrix A can be conjugate symmetric [Hermitian matrix]). The matrix may be a negative definite matrix A if the negative definite matrix can produce a useable solution.
The matrix A can be optimized. The size of A can be N pilots×N pilots, and the number of filters can be interpreted as the rank of A≦N pilots. The advantage of optimizing A instead of optimizing {tilde over (C)}, can be that the number of filters can be implicit in the optimization. The following equivalence can exist:
The quadratic form of the estimator y*Ay may not be optimal in general (for example, in the sense of maximum likelihood), but the estimator y*Ay may be optimal for quadratic criterion (like minimum mean square error).
In the following, the Gaussian probability distribution for the channel h and the noise v (where the channel and noise are independent) can be assumed, which can be represented by Equations 5, 6, and 7.
h˜N(0,Λhh) [Equation 5]
v˜N(0,σ2I) [Equation 6]
y=h+v˜N(0,Λhh+σ2I) [Equation 7]
The assumption can be for a SISO wireless network, where the vector can be over pilot location in time and frequency.
For bias normalization, the received pilots vector y can be assumed with no channel (i.e, y=v, y can be equal to the noise only, white noise with variance σ2). The noise estimation can be represented by Equation 8, where the trace (i.e., trace (A)) of an n-by-n square matrix. A can be defined to be the sum of the elements on the main diagonal (the diagonal from the upper left to the lower right).
E{{circumflex over (σ)}2}=E{trace(v*Av)}=E{trace(vv*A)}=trace(E{vv*}·A)=trace(σ2I·A)=σ2·trace(A)trace(A)=1 [Equation 8]
In a complementary way, the distortion expression can be derived assuming no noise and the received pilots vector y equal to the channel only (i.e., y=h). The channel can be considered in time and frequency domain, in the relevant pilot locations. The distortion function can be the expected channel response after the estimation process. The distortion function can be defined by Equation 9.
D(A)=E{h*Ah)}=E{trace(A·hh*)}=trace(A·E{hh*})=trace(A·Λhh) [Equation 9]
For a signal comprised of channel plus noise (Equation 1 or y=h+v), using a normalized estimation matrix A can generate Equation 10, where SNR is the signal-to-noise ratio.
The variance of the estimator can receive a contribution from the variance of both the noise and the channel as represented by combining Equation 1 and Equation 4 to generate Equation 11. Equation 12 can be generated by applying a variance function to Equation 4.
{circumflex over (σ)}2=y*Ay=(h*+v*)A(h+v) [Equation 11]
VAR({circumflex over (σ)}2)=VAR(y*Ay) [Equation 12]
To get relative variance, Equation 11 can be normalized by
Since the elements of y may be correlated, getting a simple expression for the variance in the general case may be difficult.
So the optimization criterion can be defined as: finding positive definite matrix A, which brings the average distortion and relative variance to minimum, which can be represented by Equation 13, subject to bias normalization (i.e., Equation 8 or trace(A)=1) where α is a weighting factor, which controls the ratio between the relative variance and the distortion.
Different values for α can be selected to get different targets for optimization. The factor α can be a factor of the SNR and the number of pilots (Npilots), with the notation α(SNR, Npilots). A possible selection of the factor α can be simply
or α=SNR, which can be compliant with the normalization of the distortion.
The criterion used to select the factor α can be equivalent to minimum mean square error criterion.
In high SNR scenarios, the distortion can be more dominant so the factor α may be a larger value. On the other end, in low SNR scenarios, the relative variance can be more dominant, so the factor α may be small. The noise estimation filter can provide a good noise estimation for both high and low SNR scenarios by providing optimization for different SNR ranges using the weighting factor α.
The estimation matrix A can be designed for different number of pilots (different number of symbols). The estimation matrix A can be designed for a worst case of the smallest number of pilots (i.e., Partially Used Sub-Carrier [PUSC or Partially Used Sub-Channel] 1 cluster×2 symbols). When the number of pilots increases then the number of computations can grow quadratically. Solutions for the growing computations can be: First, if the rank of A is much smaller then Npilots, then matrix A can be decomposed into Nfilters (=rank of A) filters and use the Nfilters filters. Second, the biggest Nfilters Eigen-values of A can be used. Third, the optimized matrix A for a small number of pilots can be duplicated to get a block diagonal matrix A.
Taking the expected covariance matrix of the channel response Λhh which can be represented by Equation 14.
Λhh=E{hh*} [Equation 14]
As a positive definite matrix, matrix A is decomposed into Eigen vectors and Eigen values as represented by Equation 15 and Equation 16, where U is an Eigen vectors matrix, which is unitary with orthonormal columns, and Dhh is the Eigen values diagonal matrix.
Λhh=U·D·U* [Equation 15]
Dhh=U*·Λhh·U [Equation 16]
The matrix A used previously (e.g., in Equation 4) can be built with the same Eigen vectors as Λhh, represented by Equation 17.
A=U·D·U* [Equation 17]
Thus, selecting a diagonal non-negative matrix D, a non-negative definite matrix A is generated. The square root of A is represented by Equation 18, so the i-th estimation filter equals ui·√{square root over (di)}, where ui is the i-th column of U, and di is the i-th diagonal element of D.
√{square root over (A)}=U·√{square root over (D)} [Equation 18]
An explanation of the solution can be as follows: Define a new vector z, which can the “diagonalization” of vector y, where vector z is represented by z{circumflex over (=)}U*y. The samples of z can be uncorrelated variables (and independent in the Gaussian case). Applying an Eigen vector for vector y and vector z can be represented by Equation 19 and Equation 20, respectively.
Λyy=U·Dyy·U*=U·(Dhh+σ2I)·U* [Equation 19]
Λzz=E{z*z}=Dyy=Dhh+σ2I [Equation 20]
Then, squaring the samples without filtering (diagonal A, which is the square root of D) can provide a solution.
In general form, the matrix B is defined as B{circumflex over (=)}U*AU, which can be the estimation matrix for vector z. Matrix B can be split into diagonal matrix D and the non-diagonal elements in matrix C (matrix C includes cross terms only, and the diagonal can be zero). As shown later, the matrix C may be equal to zero. The variance of the estimator for vector y and vector z can be represented by Equation 21 and Equation 22, respectively.
{circumflex over (σ)}2=y*Ay=y=y*UU*AUU*y=z*·(U*AU)·z{circumflex over (=)}z*Bz [Equation 21]
{circumflex over (σ)}2=z*Bz=z*Cz+z*Dz [Equation 22]
An optimization constraint can be for non-negative matrix A, represented by Equation 23, where universal quantifier ∀ can mean “for all values of x in the domain”. Another optimization constraint can be for bias normalization, represented by Equation 24.
For calculation of the distortion, the expectation of the estimator (Equation 8) is used with optimization constraints to generate Equation 25, so the distortion is calculated using Equation 9, provided above, to be Equation 26. The non-diagonal values in matrix C may not contribute to the expectation (the expectation of zCz can be zero).
When calculating the variance, the part zDz can be uncorrelated to the part zCz and hence the total variance can be the sum of the variances of the two parts. Since the variance can be non-negative, then the variance of part zCz can enlarge the total variance, as represented by Equation 27. Thus, when minimizing the variance, matrix C may be omitted (with a value of zero), since matrix C may enlarge the variance and may not contribute to the expectation, as represented by Equation 28 (derived from Equation 12).
So the total optimization function in term of the matrix D is represented by Equation 29, when α is taken to be
and where s.t. can mean “such that” (or “so that”).
The total optimization function is optimized for variance and distortion. Optimizing for variance, the matrix D is represented by
Optimizing for distortion, the matrix D is represented by
where 0 is a zero matrix, and the 1 corresponds to the location of the smallest Eigen value in Dhh.
A solution using both variance and distortion can depend on the ratio between the optimization criteria, which can be suited for different SNR values.
Lagrange multipliers is used to optimize the function represented by Equation 29, which can generate Equation 30.
Taking a derivative of the function in Equation 30 and comparing the derivative to zero is used to generate a noise coefficient that can be used in a noise estimation filter, represented by Equation 31. Equation 31 can be similar to Expression 1 and Expression 2 provided above.
The noise estimation filters (shown in
Various techniques, or certain aspects or portions thereof, may take the form of program code (i.e., instructions) embodied in tangible media, such as floppy diskettes, CD-ROMs, hard drives, or any other machine-readable storage medium wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the various techniques. In the case of program code execution on programmable computers, the computing device may include a processor, a storage medium readable by the processor (including volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. The volatile and non-volatile memory and/or storage elements may be a RAM, EPROM, flash drive, optical drive, magnetic hard drive, or other medium for storing electronic data. The base station and mobile station may also include a transceiver module, a counter module, a processing module, and/or a clock module or timer module. One or more programs that may implement or utilize the various techniques described herein may use an application programming interface (API), reusable controls, and the like. Such programs may be implemented in a high level procedural or object oriented programming language to communicate with a computer system. However, the program(s) may be implemented in assembly or machine language, if desired. In any case, the language may be a compiled or interpreted language, and combined with hardware implementations.
It should be understood that many of the functional units described in this specification have been labeled as modules, in order to more particularly emphasize their implementation independence. For example, a module may be implemented as a hardware circuit comprising custom VLSI circuits or gate arrays, off-the-shelf semiconductors such as logic chips, transistors, or other discrete components. A module may also be implemented in programmable hardware devices such as field programmable gate arrays, programmable array logic, programmable logic devices or the like.
Modules may also be implemented in software for execution by various types of processors. An identified module of executable code may, for instance, comprise one or more physical or logical blocks of computer instructions, which may, for instance, be organized as an object, procedure, or function. Nevertheless, the executables of an identified module need not be physically located together, but may comprise disparate instructions stored in different locations which, when joined logically together, comprise the module and achieve the stated purpose for the module.
Indeed, a module of executable code may be a single instruction, or many instructions, and may even be distributed over several different code segments, among different programs, and across several memory devices. Similarly, operational data may be identified and illustrated herein within modules, and may be embodied in any suitable form and organized within any suitable type of data structure. The operational data may be collected as a single data set, or may be distributed over different locations including over different storage devices, and may exist, at least partially, merely as electronic signals on a system or network. The modules may be passive or active, including agents operable to perform desired functions.
Reference throughout this specification to “an example” means that a particular feature, structure, or characteristic described in connection with the example is included in at least one embodiment of the present invention. Thus, appearances of the phrases “in an example” in various places throughout this specification are not necessarily all referring to the same embodiment.
As used herein, a plurality of items, structural elements, compositional elements, and/or materials may be presented in a common list for convenience. However, these lists should be construed as though each member of the list is individually identified as a separate and unique member. Thus, no individual member of such list should be construed as a de facto equivalent of any other member of the same list solely based on their presentation in a common group without indications to the contrary. In addition, various embodiments and example of the present invention may be referred to herein along with alternatives for the various components thereof. It is understood that such embodiments, examples, and alternatives are not to be construed as defacto equivalents of one another, but are to be considered as separate and autonomous representations of the present invention.
Furthermore, the described features, structures, or characteristics may be combined in any suitable manner in one or more embodiments. In the following description, numerous specific details are provided, such as examples of layouts, distances, network examples, etc., to provide a thorough understanding of embodiments of the invention. One skilled in the relevant art will recognize, however, that the invention can be practiced without one or more of the specific details, or with other methods, components, layouts, etc. In other instances, well-known structures, materials, or operations are not shown or described in detail to avoid obscuring aspects of the invention.
While the forgoing examples are illustrative of the principles of the present invention in one or more particular applications, it will be apparent to those of ordinary skill in the art that numerous modifications in form, usage and details of implementation can be made without the exercise of inventive faculty, and without departing from the principles and concepts of the invention. Accordingly, it is not intended that the invention be limited, except as by the claims set forth below.
Number | Name | Date | Kind |
---|---|---|---|
20050105657 | Kroeger et al. | May 2005 | A1 |
20060109922 | Gorokhov et al. | May 2006 | A1 |
20060154608 | Fukuoka et al. | Jul 2006 | A1 |
20070058740 | Akahori | Mar 2007 | A1 |
20090122900 | Mege et al. | May 2009 | A1 |
20090247107 | Roy et al. | Oct 2009 | A1 |
20100067366 | Nicoli | Mar 2010 | A1 |
Number | Date | Country |
---|---|---|
2013003589 | Jan 2013 | WO |
2013003589 | Apr 2013 | WO |
Entry |
---|
International Search Report and Written Opinion received for PCT application No. PCT/US2012/044643, mailed on Feb. 1, 2013, 9 pages. |
Number | Date | Country | |
---|---|---|---|
20130003802 A1 | Jan 2013 | US |