Embodiments disclosed herein relate to related to encoding and/or decoding channel state information (CSI) and/or pilot sequences. In particular, the present invention relates to an encoder for encoding a vector comprising channel state information and/or a pilot sequence. The present invention also relates to a decoder for decoding a vector comprising channel state information and/or a pilot sequence from a binary representation. Further, the present invention also relates to a communication system and to methods for decoding and/or encoding channel state information and/or pilot sequences. The present invention also relates to a computer-readable storage medium storing program code, the program code comprising instructions for carrying out the above methods.
In order to feed back channel state information over the air from a User Equipment to a Base Station, it needs to be quantified and the quantized CSI needs to be mapped into a sequence of bits. The feedback can be performed between any two communicating devices (e.g. feedback between two user equipments, between two base stations, etc.). The terminology “Base Station”(BS) and “User Equipment”(UE) will be used in the following merely for the sake of simplicity.
The User Equipment knows a CSI vector “h0” through some non-precise process and wants to feed back a normalized version of this vector denoted by “h” to the base station.
The size of the vector “h” (denoted by “D” in the following) can e.g. correspond to the number of antennas of the Base Station. Since the UE cannot send h with infinite precision, it has to send a “compact” representation of this vector “h”. This feedback is performed by transmitting a sequence of B bits (b1, . . . , bB) representing an approximation of “h” to the Base Station.
Current standardized codebooks are only available for low dimensions (small B) and low number of bits (small B). Some automatic designs have been proposed for large dimension. However, their performance and/or their complexity can be suboptimal.
The objective of the present invention is to provide an encoder, a decoder, a communication system and a method which overcome one or more of the above-mentioned problems of the prior art.
A first aspect of the invention provides an encoder for encoding a vector comprising channel state information and/or a pilot sequence, the encoder comprising:
The encoder of the first aspect has the advantage that the encoding has a low complexity while still achieving a high coding efficiency.
The determining unit can be configured to determine the initial cell of the initial sphere mesh and to determine the refined cell of the refined sphere mesh. Thus, the new (refined) sphere mesh comprises the initial sphere mesh, wherein only the initial cell has been further refined. Alternatively, the refined sphere mesh is only the initial sphere mesh, wherein only the initial cell has been further refined.
The encoder of the first aspect can be configured to first determine an initial sphere mesh. For example, it can comprise an initial mesh unit configured to determine the initial sphere mesh. In particular, the initial sphere mesh can be built based on knowledge that is shared between user equipment and base station, e.g. based on covariance information of the channel state information.
Typically, the vector comprising the channel state information is a unit-norm vector. The first and/or second identifiers can be indices.
The encoder of the first aspect addresses the problem of efficient quantization. For example, it can be used for feedback between two multiple-antennas communicating devices of a unit-norm vector representing a “part” of the Channel State Information. In the following, we will not distinguish between the unit-norm vector and the CSI when there is no ambiguity.
In a first implementation of the encoder according to the first aspect, the mesh refinement unit is configured to determine the refined sphere mesh by iteratively splitting a cell of the initial sphere mesh.
This represents an efficient way of determining the refined sphere mesh with the desired accuracy. Preferably, the splitting is performed only for the initial cell of the initial sphere mesh. For example, a cell can be split into two cells. Thus, an initial sphere mesh can be recursively further refined.
In a second implementation of the encoder according to the first aspect as such or according to the first implementation of the first aspect, the mesh refinement unit is configured to determine the refined sphere mesh by defining a grid on a cell of the initial sphere mesh.
This represents a further efficient way of determining the refined sphere mesh. Preferably, this is performed only for the initial cell of the initial sphere mesh. Preferably, the same grid is applied to all cells of the initial sphere mesh.
In a third implementation of the encoder according to the first aspect as such or according to any of the preceding implementations of the first aspect, the vector is a complex-valued vector and the initial sphere mesh is a sphere mesh on a complex-valued sphere.
Thus, cells of the complex-valued sphere mesh can directly represent complex-valued vectors.
In a fourth implementation of the encoder according to the first aspect as such or according to any of the preceding implementations of the first aspect, the vector is a real-valued vector that is determined by a vector conversion unit based on a complex input vector.
In a fifth implementation of the encoder according to the first aspect as such or according to any of the preceding implementations of the first aspect, the encoder is configured to determine a binary representation for each of a plurality of vectors comprising channel state information and/or pilot sequences corresponding to a plurality of antennas of a multiple-antenna user equipment.
Thus, the encoder can be used for transmitting channel state information and/or pilot sequences of multiple-antenna user equipment.
In a sixth implementation of the encoder according to the first aspect as such or according to any of the preceding implementations of the first aspect, the encoder further comprises a transmission unit configured to transmit the binary representation over a wireless connection.
For example, the encoder can be part of a user equipment or a base station of a wireless communication system. Since the encoder can provide a suitable binary representation with low computational effort, the encoder is particularly useful for mobile devices which have limitations on energy consumption and/or computational processing power.
A second aspect of the invention refers to a decoder for decoding a vector comprising channel state information and/or a pilot sequence from a binary representation, the decoder comprising:
The decoder can be configured to decode the binary representation determined by the encoder of the first aspect. The refined vector unit can be configured to determine the refined cell vector based on the refined sphere mesh as determined by the mesh refinement unit.
In a first implementation of the decoder of the second aspect, the mesh refinement unit is configured to:
In particular, the mesh refinement unit can be configured to split the initial cell into two cells, and then to iteratively split the two cells into four cells, eight cells, and so on. Preferably, the cells are not all effectively computed, but the splitting of cells is effective only for the cells containing the input vectors. The mesh refinement unit can be configured to determine one of the two cells resulting from the splitting of the cell of the initial sphere mesh, then to determine one of the two cells resulting from the splitting of the first determined cell and so on.
The mesh refinement unit can thus successively increase the accuracy until the desired accuracy is reached.
The mesh refinement unit can also be configured to define a grid on a cell of the initial sphere mesh, e.g. on the initial cell of the initial sphere mesh. This has the advantage that in one step the desired accuracy level can be reached.
A third aspect of the invention refers to a communication system comprising:
The first node can comprise a transmitter configured to transmit the binary representation that is determined by the encoder. The second node can comprise a receiver configured to receive the binary representation that is transmitted by the first node.
A fourth aspect of the invention refers to a method for encoding a vector comprising channel state information and/or a pilot sequence, the method comprising:
The methods according to the fourth aspect of the invention can be performed by the encoder according to the first aspect of the invention. Further features or implementations of the method according to the fourth aspect of the invention can perform the functionality of the encoder according to the first aspect of the invention and its different implementation forms.
In a first implementation of the method of the fourth aspect, refining the initial sphere mesh comprises iteratively splitting cells of the initial sphere mesh.
In a second implementation of the method of the fourth aspect as such or according to any of the preceding implementations of the third aspect, the vector is a real-valued vector and the method comprises an initial step of converting a complex input vector into the real-valued vector.
A fifth aspect of the invention refers to a method for decoding a vector comprising channel state information and/or a pilot sequence from a binary representation, the method comprising:
The methods according to the fifth aspect of the invention can be performed by the decoder according to the second aspect of the invention. Further features or implementations of the method according to the fifth aspect of the invention can perform the functionality of the decoder according to the second aspect of the invention and its different implementation forms.
A sixth aspect of the invention refers to a computer-readable storage medium storing program code, the program code comprising instructions for carrying out the method of the fourth aspect, one of the implementations of the fourth aspect, the fifth aspect, or one of the implementations of the fifth aspect.
To illustrate the technical features of embodiments of the present invention more clearly, the accompanying drawings provided for describing the embodiments are introduced briefly in the following. The accompanying drawings in the following description are merely some embodiments of the present invention. Modifications on these embodiments are possible without departing from the scope of the present invention as defined in the claims.
The determining unit 110 is configured to determine a cell of a sphere mesh, wherein the cell includes the vector. For example, the determining unit 110 can be configured to determine an initial cell of an initial sphere mesh, wherein the initial cell includes the vector. The determining unit 110 can further be configured to determine a refined cell of a refined sphere mesh, wherein the refined cell includes the vector.
The mesh refinement unit 120 is configured to determine a refined sphere mesh based on an initial sphere mesh.
The representation unit 130 is configured to determine a binary representation of a first identifier of an initial cell of the initial sphere mesh that includes the vector and a second identifier of a refined cell of the refined sphere mesh that includes the vector.
The decoder comprises an initial vector unit 210, a mesh refinement unit 220 and a refined vector unit 230.
The initial vector unit 210 is configured to determine an initial cell vector based on a first part of the binary representation and an initial sphere mesh. The initial sphere mesh can be predetermined sphere mesh, e.g. stored in a memory of the decoder.
The mesh refinement unit 220 is configured to determine a refined sphere mesh based on the initial sphere mesh.
The refined vector unit 230 is configured to determine a refined cell vector based on the refined sphere mesh and a second part of the binary representation.
The first node 310 comprises an encoder 100, e.g. the encoder 100 of
The method comprises a second step 420 of refining the initial sphere mesh to obtain a refined sphere mesh.
The method comprises a third step 430 of determining a refined cell of the refined sphere mesh that includes the vector.
The method comprises a fourth step 440 of representing a first identifier of the initial cell and a second identifier of the refined cell as a binary representation. The method 400 can be carried out e.g. by the encoder 100 of
Suppose that a non-precise process leads the UE to know a D0-dimensional vector comprising the channel state information, wherein D0 is the number of antennas at the base station, the vector denoted by h0. h0 may refer for example to a tap in the time domain of the channel between all D0 antennas of Base Station and the antenna of UE.
The fact that the CSI is represented only as a vector (and not a matrix) is due to the assumption that the UE has a single antenna. This assumption is done for the sake of simplicity. If the UE has multiple antennas, one can use the single-antenna case as detailed further below.
The UE can compute a unit-norm vector h from ho representing e.g. a part of the channel state information.
In a first embodiment, the unit-norm vector h can be computed as:
In that case the dimension of the vector h is D=D0.
In a second embodiment, h can be computed as:
where U is a D0xD unitary matrix. The dimension of h is then equal to D.
A third embodiment may be considered through another scenario. A base station may be configured to compute a complex vector representing a pilot sequence P that another communication device (for example, a user equipment) should transmit. In that case, the pilot sequence needs to be quantized, that is to say represented through bits in order that these bits can be transmitted to the communication device. In that case, the unit vector can be the normalized version of this pilot:
The task of the encoder can be to compute a binary representation, e.g. a sequence of bits (b1, . . . , bB), representing a unit-norm vector “h”.
We use the notion of codebook as a list of representative vectors approximating the true vector “h”. Herein, a codebook is a list of vectors (or codewords denoted by v(1), . . . , v(2B)) on the sphere that can be sent over the air through the binary representation of their index (comprised between 1 and 2B).
The method 500 comprises a first step 510 of determining an initial cell vector based on a first part of the binary representation and an initial sphere mesh.
The method 500 comprises a second step 520 of determining a refined sphere mesh based on the initial sphere mesh.
The method 500 comprises a third step 530 of determining a refined cell vector based on the refined sphere mesh and a second part of the binary representation.
The mesh of the sphere can then be seen as a set of vectors of the sphere 600 closest to each codeword 610. One can then equivalently either define the codewords 610 and compute the mesh 605 related to these codewords 610 or design the mesh 605 and consider the center of each cell 620 of the mesh 605 as a codeword. Once these codewords 610 (or this mesh 605) are defined, the encoder can consider the “vector to be quantized” (the unit-norm vector h) and find the closest codeword to this vector (namely “quantized vector” which is then an approximation of the true vector h). The binary representation of the index of this “quantized vector” can then be sent to decoder, e.g. a base station.
A proposed encoder numerically computes a sequence of bits from a unit-norm CSI vector (denoted above by h). We will propose in next section three different preferred embodiments of the following major steps:
Step 1: Compute a real representative of h (only for first two embodiments). For example, by noting ϕ=arg(h1) the angle of the first coordinate of h, one can define a rotated equivalent vector h(r) as h(r)=he−iϕ and we convert h(r) into a unit-norm real vector:
In the following, d will denote the size of g (that is to say d=2D-1).
Step 2: Compute an initial representative vector and its corresponding index as well as its binary representation; this constitutes the first bits of the sent sequence.
Step 3: Compute the remaining bits defining the relative position of the codeword with respect to the initial representative vector.
In a first preferred embodiment, an initial mesh is iteratively divided on the sphere by cutting in two parts each cell of the mesh.
The definition of the initial mesh can be constituted by d codewords (v(1), . . . ,v(d)) of coordinates v(1)=(1,0,0,0, . . . ), v(2)=(0,1,0,0, . . . ), . . . v(d)=(0,0, . . . , 0,1).
In the initial mesh, the index of the cell 820 containing g is computed through:
i*=arg max(|g1|, . . . , |gd|).
The d cells of the mesh are the set of points closest to each codeword. The idea is to iteratively split these cells. The division of a cell 820 into two cells 822, 824 can be performed with respect to a plan whose equation depends on the cell. The two new cells 822, 824 correspond to two new codewords 812, 814.
It is not necessary for the encoder to build all the cells of the refined mesh. It can be sufficient to iteratively find the refined cell among the two cells obtained by splitting the initial cell 820.
Each split then multiplies the total number of codewords in the codebook by 2. With this method, we are able to define codebooks with different size (the number of codewords depends on the number of splits in the construction). The construction method also provides a way to compute the representative codeword. The idea is that at each step (that is to say at each split) of the codebook construction, we identify the cell in which the “vector to be quantized” belongs.
In a second preferred embodiment, a grid is built on the initial cell, which is defined as the cell in the initial mesh considered in
For each cell of the initial mesh, we are able to define an abstract mapping between each cell and the unit (d-1)-dimensional cube. Let Ci*be the initial cell computed at step 2. We define a mapping Ti* between Ci* and the unit cube by:
Ti*: Ci* →[0;1]d-1
g=(g1, . . . , gd)T(u1, . . . , ud-1)T
with for any 1≤i≤d-1
One then defines a regular grid on this unit cube. The sent sequence of bits in Step 3 is then the binary representation of the closest point on this grid (the representative codeword on the sphere is then the inverse mapping of this closest point), i.e. the concatenation of the binary representation of
where Bi is the number of bits used to quantize ui.
In a third preferred embodiment, a grid 930 is built on each cell 920 of the initial mesh considered in
This leads to the definition of a different mapping from the initial cell to the unit cube. The remaining steps are the same as in the third embodiment. More precisely, the index of the initial cell is computed as:
i*=arg max(|h1|, . . . , |hD)
and if Ci* is this initial cell computed at step 2, the mapping Si* used at Step 3 is defined by:
Si*: Ci* →[0;1]2D-2
x=(h1, . . . , hD)Ta=(u1, v1, . . . , uD-1, vd-1)T
with for any 1≤i≤D1, ui=N(Re(wi)) and vi=N(Im(wi)) (where N is the cumulative distribution function of the univariate standard Gaussian distribution) and
Finally the sent sequence of bits is the concatenation of the concatenation of the binary representation of
where Bi is the number of bits used to quantize ai, the i-th component of vector a.
A decoder is configured to perform a reverse operation to the above-described operation of the encoder. It computes the representative vector from a sequence of bits. For example, a decoder can be configured to, in a first step, compute the codeword index form the sequence of bits. In a second step, it can compute the codeword associated to this index.
The decoder implementation can have a similar structure as the encoder. In an embodiment, the decoder can be configured to:
The mathematical details are symmetric with respect to the encoder part with the same distinction between the three possible implementations.
The above-described feedback methods can be used e.g. for a single-antenna UE. A simple extension is to extend the method to multiple-antenna UE (denote the number of antennas at UE by N). In that case, the CSI to feedback can be a set of N unit-norm vectors. Typically, a preprocessing to compute these N unit-norm vectors has to be performed.
One can then separately encode the N vectors and feed back the corresponding bits through the aforementioned method.
The following table summarizes characteristics of prior art methods and an embodiment of the proposed method suitable for large codebooks of 2B elements in a space of size D.
Embodiments of the present invention can have one or more of the following advantages:
Very low complexity of coding and decoding algorithm.
No storage needed at either BS and UE.
Performances competes with prior art.
Flexibility.
No parameterization or calibration needed.
Any precision can be reached.
Codebook available for any number of antennas.
Possible scaling with the number of antennas and the number of needed bits.
The foregoing descriptions are only implementation manners of the present invention, the scope of the present invention is not limited to this. Any variations or replacements can be easily made through person skilled in the art. Therefore, the protection scope of the present invention should be subject to the protection scope of the attached claims.
This application claims is a continuation of International Application No. PCT/EP2016/069065, filed on Aug. 10, 2016. the disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2016/069065 | Aug 2016 | US |
Child | 16270505 | US |