The present disclosure relates generally to channel parameter estimation for a wireless communication system. More particularly, it relates to implementations of methods and systems that may achieve higher overall throughput and improve communication efficiency via finite rate of innovation channel parameter estimation for a CDMA communication system.
In a communication system, e.g., a code-division multiple access (CDMA) system, a Rake receiver may be used for separating multipath propagated signal components after reception and before combining the multipath propagated signal components for decoding. In general, the signal components are then separated from each other at least by using a part of a spreading code of a pilot signal. The Rake receiver comprises Rake fingers where despreading and diversity combination take place. In addition, the received signal may also include, in addition to the desired signal, noise and interference caused by other users or systems. In systems utilizing diversity, the influence of multipath signals, noise and interference can be decreased by using a diversity combining technique and/or an equalizer.
In the conventional Rake receiver, the combining of the multipath signals can be accomplished by using different diversity combining techniques, in addition to a maximum ratio combining (MRC) method, such as by using equal gain combining and signal-to-interference ratio (SIR) combining. The end result is an indication of how multipath signals are weighted before summing. Of these methods, SIR combining is typically preferred since it gives the best performance. However, SIR combining is significantly more complex than other approaches, resulting in sub-optimal methods, such as MRC, being used for practical reasons.
One challenge to the use of a MRC Rake is that under certain conditions it can result in performance that is less than what would be expected. If a RAKE receiver or an equalizer cannot properly detect a delay value and a relative peak value of a multipath signal component, a RAKE finger may be allocated to a time instant where there in reality is no desired signal, the finger will add interference only to the combined signal and finally decrease the performance of a receiver.
Various implementations of systems, methods and devices within the scope of the appended claims each have several aspects, no single one of which is solely responsible for the desirable attributes described herein. Without limiting the scope of the appended claims, some prominent features are described herein.
Details of one or more implementations of the subject matter described in this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages will become apparent from the description, the drawings, and the claims. Note that the relative dimensions of the following figures may not be drawn to scale.
In one aspect an apparatus for equalizing received signals is provided. The apparatus comprises a signal processing unit configured to process received pilot signals transmitted through a wireless channel into at least one composite signal. The apparatus further comprises a Fourier transform unit configured to transform the at least one composite signal into frequency-domain data and estimate at least one delay value of the wireless channel from the frequency-domain data.
Another aspect provides a method of equalizing received signals. The method comprises processing received pilot signals transmitted through a wireless channel into at least one composite signal, transforming the at least one composite signal into frequency-domain data, and estimating at least one delay value from the frequency-domain data.
Another aspect provides an apparatus for equalizing received signals. The apparatus comprises means for wirelessly receiving signals, and means for processing received pilot signals into at least one composite signal. The apparatus further comprises means for estimating at least one delay value and at least one peak value from the composite signal.
In another aspect, a non-transient computer readable media is provided having instructions stored thereon that cause a wireless communication apparatus to perform the method of processing received pilot signals transmitted through a wireless channel into at least one composite signal, transforming the at least one composite signal into frequency-domain data, and estimating at least one delay value from the frequency-domain data.
The various features illustrated in the drawings may not be drawn to scale. Accordingly, the dimensions of the various features may be arbitrarily expanded or reduced for clarity. In addition, some of the drawings may not depict all of the components of a given system, method or device. Finally, like reference numerals may be used to denote like features throughout the specification and figures.
The detailed description set forth below in connection with the appended drawings is intended as a description of exemplary embodiments of the invention and is not intended to represent the only embodiments in which the invention may be practiced. The term “exemplary” used throughout this description means “serving as an example, instance, or illustration,” and should not necessarily be construed as preferred or advantageous over other exemplary embodiments. The detailed description includes specific details for the purpose of providing a thorough understanding of the exemplary embodiments of the invention. In some instances, some devices are shown in block diagram form.
While for purposes of simplicity of explanation, the methodologies are shown and described as a series of acts, it is to be understood and appreciated that the methodologies are not limited by the order of acts, as some acts may, in accordance with one or more aspects, occur in different orders and/or concurrently with other acts from that shown and described herein. For example, those skilled in the art will understand and appreciate that a methodology could alternatively be represented as a series of interrelated states or events, such as in a state diagram. Moreover, not all illustrated acts may be required to implement a methodology in accordance with one or more aspects.
Before turning to the wireless communication methods in more detail, example wireless communication device hardware will be described with reference to
The wireless device 106 may include a processor 184 which controls operation of the wireless device 106. The processor 184 may also be referred to as a central processing unit (CPU). Memory 186, which may include both read-only memory (ROM) and random access memory (RAM), provides instructions and data to the processor 184. A portion of the memory 186 may also include non-volatile random access memory (NVRAM). The processor 184 typically performs logical and arithmetic operations based on program instructions stored within the memory 186. The instructions in the memory 186 may be executable to implement the methods described herein. The processor 184 may comprise or be a component of a processing system implemented with one or more processors. The one or more processors may be implemented with any combination of general-purpose microprocessors, microcontrollers, digital signal processors (DSPs), field programmable gate array (FPGAs), programmable logic devices (PLDs), controllers, state machines, gated logic, discrete hardware components, dedicated hardware finite state machines, or any other suitable entities that can perform calculations or other manipulations of information.
The processing system may also include machine-readable media for storing software. Software shall be construed broadly to mean any type of instructions, whether referred to as software, firmware, middleware, microcode, hardware description language, or otherwise. Instructions may include code (e.g., in source code format, binary code format, executable code format, or any other suitable format of code). The instructions, when executed by the one or more processors, cause the processing system to perform the various functions described herein.
The wireless device 106 may also include a transmitter 190 and a receiver 192 to allow transmission and reception of data between the wireless device 106 and other wireless communication devices. The transmitter 190 and receiver 192 may be combined into a transceiver 194. An antenna 196 may be provided and electrically coupled to the transceiver 194. The wireless device 180 may also include (not shown) multiple transmitters, multiple receivers, multiple transceivers, and/or multiple antennas.
The wireless device 106 may also include a signal detector 200 that may be used in an effort to detect and quantify the level of signals received by the transceiver 194. The signal detector 200 may detect such signals as total energy, energy per subcarrier per symbol, power spectral density and other signals. The wireless device 106 may also include a digital signal processor (DSP) 202 for use in processing signals. The DSP 202 may be configured to generate a data unit for transmission. The wireless device 106 may further comprise a display 204, and a user interface 206. The user interface 206 may include a touchscreen, keypad, a microphone, and/or a speaker. The user interface 206 may include any element or component that conveys information to a user of the wireless device 106 and/or receives input from the user.
The various components of the wireless device 106 may be coupled together by one or more bus systems 208. The bus systems 208 may include a data bus, for example, as well as a power bus, a control signal bus, and a status signal bus in addition to the data bus. Those of skill in the art will appreciate the components of the wireless device 106 may be coupled together or accept or provide inputs to each other using some other mechanism.
Although a number of separate components are illustrated in
This transmitted signal is then sent to the receiver over a sparse channel. For a sparse channel, the channel impulse response can be modeled as a sum of K Dirac functions, one for each path of the channel, each with a complex weight ck and a tap position tk as follows:
Referring now to
The received signal is down-converted with a frequency offset Δωc:
This down-converted signal is filtered with a root raised cosine filter 332 in the receiver. The filtered output is processed by a rake receiver 350 for decoding. The filtered output is also processed at block 334, where pilot dispreading and cross-correlation are performed. The module 334 despreads the signal with the all one Hadamard encoding sequence and determines the cross correlation between the received pilot signal and the known pilot signal to produce a composite signal. The despreading and cross-correlation sequence is:
The cross-correlation is a matched filter corresponding to a convolution of the filtered signal with a negative time version of the depsreading and cross correlation sequence:
Where Ap(l) is the autocorrelation sequence:
And where r cos( ) represents the raised cosine impulse response.
Assuming no frequency offset on the down-conversion and taking all the autocorrelation terms to be noise except the zero lag term, the output of the pilot dispreading and correlation module 334 is:
Wherein function r cos is the raised cosine impulse response function, ck and tk are the channel amplitudes and tap positions respectively, and ntot is the crosstalk pulse interference and noise.
The inventors have observed that a frequency-domain representation of such a correlation output comprises a sum of exponentials with unknown envelopes and phases.
Where RCOS( ) is the raised cosine frequency response.
The envelopes and phases of these exponentials indicate amplitudes and tap positions (or delays) of a channel impulse response (CIR) of a sparse wireless channel. It will be appreciated that although the above mathematical analysis is presented in the continuous time domain, A/D conversion will be performed in the receiver and the dispreading/cross correlation and Fourier Transform will be performed in the digital domain according to well known digital processing techniques. The frequency response of the raised cosine function is flat within the passband, and the discrete Fourier Transform output of module 336 can be expressed as follows:
Because the output of the Fourier Transform module 336 has this form, finite rate of innovation (FM) signal processing may be used to derive the amplitudes and tap positions of the channel impulse response. These values can then be used to perform channel equalization on the received data signals.
FRI signal processing is a method of analyzing signals with a “finite rate of innovation.” One such class of signals are signals made up of a series of relatively narrow pulses. For a wireless communication system, more particularly, a CDMA communication system, a FRI signal processing method may be used for estimating one or more CIR parameters of a wireless channel, such as amplitudes, delays and/or a rank of the wireless channel.
Several mathematical techniques for FRI signal processing are well known. A description of one such method applied to signals comprising a series of narrow pulses is described in Vetterli, et al., Sampling Signals With Finite Rate of Innovation, IEEE Transactions On Signal Processing, Vol. 50, No. 6 (June 2002).
Generally, FRI signal processing when applied to a signal that is made up of a series of relatively narrow and separated pulses includes low pass filtering the signal, sampling and digitizing the filtered signal with an A/D converter, and Fourier transforming the output of the A/D converter to produce a set of frequency domain Fourier coefficients. When the original signal is a series of narrow pulses, the Fourier coefficients will define a functional form of a series of sinusoids, each defined by a position and amplitude of one of the pulses of the series. Finding the positions and amplitudes of the pulses thus reduces to the problem of extracting separately the amplitudes and phases of the sinusoids that are buried in the sum that the Fourier coefficients follow. In this application of FRI signal processing, a set of the Fourier coefficients are used as an input for mathematical techniques that extract the separate phases and amplitudes of this series of sinusoids, which in turn indicate the positions and amplitudes of the pulses in the original signal.
To implement an FRI signal processing method in the receiver of
A variety of mathematical techniques can be used to extract the amplitudes and phases of the sinusoids from the frequency domain data to implement the method illustrated in
These filter coefficients (sometimes referred to herein as Prony values) define a polynomial (sometimes referred to herein as as a Prony polynomial):
The roots of this polynomial (sometines referred to herein as Prony roots) are the values uk from which the delays tk can be found. Once the values for uk are known, linear algebra can be used to perform a least squares fit using a second matrix equation (e.g. a second Prony matrix equation):
In the presence of noise, L will be greater than K, and N will be greater than 2K. L may be referred to as the overfit parameter. In some suitable embodiments, N is selected to be 2L+1, making the above matrix F square.
At block 516, two submatrices with fixed delay between entries are extracted from the above matrix F:
It can be shown that the Prony roots (corresponding to the tap delays) are the eigenvalues of the matrix F1†F2, where F1† indicates the pseudoinverse of F1. Thus at block 518, eigenvalues are solved for to determine the Prony roots uk, from which the delays and gains can be derived as set forth above.
The method of
With this matrix, M is at least K, and is desirably greater than K. In the presence of noise, the rank of this matrix will be greater than K. At block 604, a singular value decomposition is performed on the Toeplitz matrix to produce a reduced rank approximation of the above Toeplitz matrix having rank K. At block 606, this rank K matrix is then made Toeplitz again by replacing the each set of diagonal entries by the average along each diagonal. The system iterates between the rank K projection at block 604 and the Toeplitz projection at block 606, checking each time at decision block 608 for convergence within some determined threshold. When the denoising loop is complete, the denoised frequency domain data from the first row and column of the converged rank K matrix can be used to form a Toeplitz matrix for use in the Prony procedure as described above. at block 610 Prony values from a first Prony matrix equation based on the Toeplitz matrix are found. At block 612, Prony roots from a Prony polynomial are found. At block 614, channel parameters are estimated from a second Prony matrix equation based on the Prony roots.
The method of
It has been noted that in actual practice, the tap delays in typical wireless channels change much slower than the channel tap gains, and thus it is possible to stack successive assembled Hankel or Toeplitz matrices and perform the above processing techniques to find the tap delays on a buffered series of matrices stacked into a single matrix. This method, however, requires memory and computation time that makes it expensive and practically difficult to implement.
In the method of
Q
out→(1−a)Qout+(a)<Y,Y>
The parameter a above can be adjusted based on the channel characteristics with smaller a for slower varying channels. An SVD and rank reduction on Qout can be performed as above, and at block 830, channel delays and channel gains are estimated from the filtered quadratic matrix Qout using methods such as described with reference to
The method of
Y
fb
=[Y; conj(Y*J)]
In the above equation, J is the antidiagonal matrix, and conj indicates replacing the entries with complex conjugates. The Y*J operation creates a right-left mirror image of Y. For Yfb, the entries correspond to frequency indices changing in one direction for the left columns, and the other direction for the right columns.
The Yfb matrix can be processed in the same manner as the matrix Y in
As used herein, the term “determining” encompasses a wide variety of actions. For example, “determining” may include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” may include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” may include resolving, selecting, choosing, establishing and the like. Further, a “channel width” as used herein may encompass or may also be referred to as a bandwidth in certain aspects.
As used herein, a phrase referring to “at least one of” a list of items refers to any combination of those items, including single members. As an example, “at least one of: a, b, or c” is intended to cover: a, b, c, a-b, a-c, b-c, and a-b-c.
The various operations of methods described above may be performed by any suitable means capable of performing the operations, such as various hardware and/or software component(s), circuits, and/or module(s). Generally, any operations illustrated in the Figures may be performed by corresponding functional means capable of performing the operations.
Information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, symbols, and chips that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
The various illustrative logical blocks, modules and circuits described in connection with the present disclosure may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array signal (FPGA) or other programmable logic device (PLD), discrete gate or transistor logic, discrete hardware components or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any commercially available processor, controller, microcontroller or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
In one or more aspects, the functions described may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media includes both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Thus, in some aspects computer readable medium may comprise non-transitory computer readable medium (e.g., tangible media). In addition, in some aspects computer readable medium may comprise transitory computer readable medium (e.g., a signal). Combinations of the above should also be included within the scope of computer-readable media.
The methods disclosed herein comprise one or more steps or actions for achieving the described method. The method steps and/or actions may be interchanged with one another without departing from the scope of the claims. In other words, unless a specific order of steps or actions is specified, the order and/or use of specific steps and/or actions may be modified without departing from the scope of the claims.
The functions described may be implemented in hardware, software, firmware or any combination thereof. If implemented in software, the functions may be stored as one or more instructions on a computer-readable medium. A storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. Disk and disc, as used herein, include compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk, and Blu-ray® disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers.
Thus, certain aspects may comprise a computer program product for performing the operations presented herein. For example, such a computer program product may comprise a computer readable medium having instructions stored (and/or encoded) thereon, the instructions being executable by one or more processors to perform the operations described herein. For certain aspects, the computer program product may include packaging material.
Software or instructions may also be transmitted over a transmission medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technologies such as infrared, radio, and microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technologies such as infrared, radio, and microwave are included in the definition of transmission medium.
Further, it should be appreciated that modules and/or other appropriate means for performing the methods and techniques described herein can be downloaded and/or otherwise obtained by a user terminal and/or base station as applicable. For example, such a device can be coupled to a server to facilitate the transfer of means for performing the methods described herein. Alternatively, various methods described herein can be provided via storage means (e.g., RAM, ROM, a physical storage medium such as a compact disc (CD) or floppy disk, etc.), such that a user terminal and/or base station can obtain the various methods upon coupling or providing the storage means to the device. Moreover, any other suitable technique for providing the methods and techniques described herein to a device can be utilized.
It is to be understood that the claims are not limited to the precise configuration and components illustrated above. Various modifications, changes and variations may be made in the arrangement, operation and details of the methods and apparatus described above without departing from the scope of the claims.
While the foregoing is directed to aspects of the present disclosure, other and further aspects of the disclosure may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.