Rate-compatible polar codes
10461779 · 2019-10-29
Assignee
Inventors
Cpc classification
H03M13/6368
ELECTRICITY
International classification
H03M13/29
ELECTRICITY
H04L1/00
ELECTRICITY
Abstract
Systems and methods are disclosed herein relating to rate-compatible polar codes and the use thereof in a wireless communications system. In some embodiments, a transmit node operable for use in a wireless communications system comprises a rate-compatible polar encoder operable to encode information bits to provide coded bits utilizing parallel concatenated polar codes. The transmit node further comprises a transmitter operable to transmit the plurality of coded bits. In this manner, the transmit node may, in some embodiments, use polar codes having different coding rates to adapt to time-varying channel conditions.
Claims
1. A transmit node operable for use in a wireless communications system, comprising: a rate-compatible polar encoder operable to encode a plurality of information bits at a plurality of different code rates and to concatenate output bits produced at one or more of the plurality of different code rates to provide a plurality of coded bits at a desired code rate; and a transmitter operable to transmit the plurality of coded bits.
2. The transmit node of claim 1 wherein the rate-compatible polar encoder comprises: a plurality of polar encoders, each operable to encode the plurality of information bits at one of the plurality of different code rates, the plurality of polar encoders comprising: a first polar encoder operable to encode the plurality of information bits at a first code rate r.sub.1 to provide a number n.sub.1 of coded bits, where n.sub.1=k/r.sub.1 and k is the number of information bits in the plurality of information bits; and a second polar encoder operable to encode a subset of the plurality of information bits at a second code rate r.sub.2 to provide a number n.sub.2 of coded bits, where r.sub.1>r.sub.2 and the number n.sub.2 of coded bits is a number of coded bits that, when concatenated with the number n.sub.1 of coded bits, transforms a resulting code word from the first code rate r.sub.1 to the second code rate r.sub.2; wherein the plurality of coded bits provided at the desired code rate r.sub.desired are a concatenation of coded bits output by polar encoders of the plurality of polar encoders for the code rates r.sub.1 through r.sub.desired.
3. The transmit node of claim 2 wherein the rate-compatible polar encoder further comprises a concatenator operable to concatenate the coded bits output by the polar encoders for the code rates r.sub.1 through r.sub.desired to provide the plurality of coded bits at the desired code rate r.sub.desired.
4. The transmit node of claim 1 wherein the rate-compatible polar encoder comprises: a plurality of polar encoders operable to encode the plurality of information bits based on corresponding polar code generator matrices for code rates r.sub.i and lengths n.sub.i, where: i={1, . . . , T}, where T is a positive integer greater than or equal to 2; n.sub.1 is a length for code rate r.sub.1 and, for all other values of i, n.sub.i is a number of additional coded bits to transform a code word for code rate r.sub.i1 into a code word for code rate r.sub.i, i.e.,
5. The transmit node of claim 4 wherein the rate-compatible polar encoder further comprises a concatenator operable to concatenate outputs of the plurality of polar encoders to provide the plurality of coded bits at the desired code rate r.sub.desired such that, for the desired code rate r.sub.desired, the plurality of coded bits is a concatenation of the outputs of the plurality of polar encoders for the code rates r.sub.1, . . ., r.sub.desired.
6. The transmit node of claim 4 wherein the polar code generator matrices for the plurality of polar encoders are submatrices G.sub.n.sub.
7. The transmit node of claim 6 wherein the plurality of polar encoders comprises: a first polar encoder for code rate r.sub.1 operable to encode the plurality of information bits at the code rate r.sub.1 to provide n.sub.1 coded bits; and one or more additional polar encoders, each additional polar encoder operable to encode a subset of the plurality of information bits consisting of a number r.sub.in.sub.i of the plurality of information bits at the code rate r.sub.i to provide n.sub.i coded bits.
8. The transmit node of claim 7 wherein, for each of the one or more additional polar encoders, the subset of the plurality of information bits encoded by the additional polar encoder is different than the subsets encoded by the other additional polar encoders.
9. The transmit node of claim 7 wherein, for each of the one or more additional polar encoders, the subset of the plurality of information bits encoded by the additional polar encoder comprises a predefined number of the plurality of information bits that are most unreliable with respect to transmission of the number n.sub.1 of coded bits from the first polar encoder.
10. The transmit node of claim 7 wherein, for at least one of the one or more additional polar encoders, an ordering of the subset of the plurality of information bits encoded by the at least one of the one or more additional polar encoders is different than an ordering of those same information bits when encoded by the first polar encoder.
11. The transmit node of claim 1 further comprising: at least one processor; and memory containing instructions executable by the at least one processor whereby the transmit node is further operable to: select an initial code rate; perform, via the rate-compatible polar encoder, polar encoding of the plurality of information bits at the initial code rate; transmit, via the transmitter, the plurality of coded bits, having been encoded at the initial code rate; upon receiving a negative acknowledgement from a receive node for the transmission of the plurality of coded bits, select a new code rate for an incremental redundancy retransmission; perform, via the rate-compatible polar encoder, polar encoding of some of the plurality of information bits to provide additional coded bits for the new code rate; and transmit, via the transmitter, the additional coded bits.
12. The transmit node of claim 11 wherein the rate-compatible polar encoder comprises: a plurality of polar encoders operable to encode the plurality of information bits based on corresponding polar code generator matrices for code rates r.sub.i and lengths n.sub.i, where: i={1, . . . , T}, where T is a positive integer greater than or equal to 2; n.sub.1 is a length for code rate r.sub.1 and, for all other values of i, n.sub.i is a number of additional coded bits to transform a code word for rate r.sub.i1 into a code word for code rate r.sub.i, i.e.,
13. The transmit node of claim 12 wherein the rate-compatible polar encoder further comprises a concatenator operable to selectively concatenate outputs of the plurality of polar encoders to provide the plurality of coded bits at the initial code rate r.sub.initial such that, for the initial code rate r.sub.initial, the plurality of coded bits is a concatenation of the outputs of the plurality of polar encoders for the code rates r.sub.1, . . . , r.sub.initial.
14. The transmit node of claim 12 wherein the additional coded bits for a new code rate r.sub.new are a concatenation of the outputs of the plurality of polar encoders for the code rates r.sub.initial+1, . . . , r.sub.new, where r.sub.newr.sub.initial+.
15. A method of operation of a transmit node in a wireless communications system, comprising: encoding a plurality of information bits at a plurality of different code rates via a plurality of polar code generator matrices to produce coded bits at the plurality of different code rates; concatenating the coded bits produced at one or more of the plurality of different code rates to provide a plurality of coded bits at a desired code rate; and transmitting the plurality of coded bits.
16. The method of claim 15 wherein encoding the plurality of information bits comprises: encoding the plurality of information bits via a first polar code generator matrix at a first code rate r.sub.1 to provide a number n.sub.1 of coded bits, where n.sub.1=k/r.sub.1 and k is a number of information bits in the plurality of information bits; and encoding a subset of the plurality of information bits via a second polar code generator matrix at a second code rate r.sub.2 to provide a number n.sub.2 of coded bits, where r.sub.1>r.sub.2 and the number n.sub.2 of coded bits is a number of coded bits that, when concatenated with the number n.sub.1 of coded bits, transforms a resulting code word from the first code rate r.sub.1 to the second code rate r.sub.2, wherein concatenating the coded bits produced at the one or more of the plurality of different code rates comprises selectively concatenating the number n.sub.1 of coded bits and the number n.sub.2 of coded bits to provide the plurality of coded bits at the desired code rate.
17. The method of claim 15 wherein encoding the plurality of information bits comprises: encoding the plurality of information bits based on the plurality of polar code generator matrices for code rates r.sub.i and lengths n.sub.i, where: i={1, . . . , T}, where T is a positive integer greater than or equal to 2; n.sub.1 is a length for code rate r.sub.1 and, for all other values of i, n.sub.i, is a number of additional coded bits to transform a code word for code rate r.sub.i1 into a code word for code rate r.sub.i, i.e.,
18. The method of claim 17 wherein the polar code generator matrices are submatrices G.sub.n.sub.
19. The method of claim 15 further comprising: selecting an initial code rate; and performing the encoding of the plurality of information bits at the initial code rate; wherein transmitting the plurality of coded bits comprises transmitting the plurality of coded bits, having been encoded at the initial code rate.
20. The method of claim 19 further comprising: upon receiving a negative acknowledgement from a receive node for the transmission of the plurality of coded bits, selecting a new code rate for an incremental redundancy retransmission; performing polar encoding of some of the plurality of coded bits to provide additional coded bits for the new code rate; and transmitting the additional coded bits.
21. The method of claim 20 wherein performing the encoding of the plurality of information bits at the initial code rate comprises: encoding the plurality of information bits based on corresponding polar code generator matrices for code rates r.sub.i and lengths n.sub.i, where: i={1, . . . , INITIAIL}, where INITIAL is an index of the initial code rate and is a positive integer greater than or equal to 1; n.sub.1 is a length for code rate r.sub.1 and, for all other values of i, n.sub.i is a number of additional coded bits to transform a code word for code rate r.sub.i1 into a code word for code rate r.sub.i, i.e.,
22. The method of claim 21 wherein the additional coded bits for a new code rate r.sub.new are a concatenation of one or more sets of coded bits resulting from encoding at least some of the plurality of information bits based on corresponding polar code generator matrices for code rates r.sub.i and lengths n.sub.i for i={INITIAL+1, . . . , NEW }, where NEW is an index of the new code rate r.sub.new.
23. A receive node operable for use in a wireless communications system, comprising: a receiver operable to receive a plurality of polar encoded bits; and a rate-compatible polar decoder operable to determine a code rate r.sub.d of the plurality of polar encoded bits and to decode the plurality of polar encoded bits according to the determined code rate to provide a plurality of information bits.
24. The receive node of claim 23 wherein, in order to decode the plurality of polar encoded bits, the rate-compatible polar decoder is operable to: determine the code rate r.sub.d of the plurality of polar encoded bits, the code rate r.sub.d being one of a predefined set of code rates {r.sub.i}.sub.i=1, . . . ,T where r.sub.i>r.sub.i+1 for i =1, . . . , T1 and T is a positive integer greater than or equal to 2; successively perform polar decoding of a last n.sub.i polar encoded bits of the plurality of polar encoded bits for code rates r.sub.d to r.sub.1 to provide sets of information bits for the code rates r.sub.d to r.sub.1, respectively, where:
25. The receive node of claim 24 wherein, in order to successively perform polar decoding of the last n.sub.i polar encoded bits of the plurality of polar encoded bits for the code rates r.sub.d to r.sub.1 to provide the sets of information bits for the code rates r.sub.d to r.sub.1, respectively, the rate-compatible polar decoder is further operable to: perform polar decoding of a last n.sub.d polar encoded bits of the plurality of polar encoded bits for the code rate r.sub.d to provide the set of information bits for the code rate r.sub.d; perform polar decoding of a next n.sub.dpolar encoded bits of the plurality of polar encoded bits using the set of information bits for the code rate r.sub.d as frozen bits to provide the set of information bits for code rate r.sub.d1; and perform polar decoding of a next n.sub.d2 polar encoded bits of the plurality of polar encoded bits using a union of the sets of information bits for code rates r.sub.d and r.sub.das frozen bits to provide the set of information bits for code rate r.sub.d2.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1) The accompanying drawing figures incorporated in and forming a part of this specification illustrate several aspects of the disclosure, and together with the description serve to explain the principles of the disclosure.
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
DETAILED DESCRIPTION
(10) The embodiments set forth below represent information to enable those skilled in the art to practice the embodiments and illustrate the best mode of practicing the embodiments. Upon reading the following description in light of the accompanying drawing figures, those skilled in the art will understand the concepts of the disclosure and will recognize applications of these concepts not particularly addressed herein. It should be understood that these concepts and applications fall within the scope of the disclosure and the accompanying claims.
(11) Systems and methods are disclosed herein relating to rate-compatible polar codes and the use thereof in a wireless communications system. In this regard,
(12) Before describing the operation of the wireless communications system 10 and, in particular, the operation of the rate-compatible polar encoder 14 and the rate-compatible polar decoder 20, a discussion of a family of rate-compatible polar codes is first provided. The family of rate-compatible polar codes is used to encode k information bits with various code rates {r.sub.i: i=1, . . . ,T}, where r.sub.1> . . . >r.sub.T and T2. The disclosed rate-compatible polar code satisfies the condition that the set of parity bits of a higher rate code should be a subset of the set of parity bits of a lower rate code, which can be used for Hybrid Automatic Repeat Request (HARQ) based on Incremental Redundancy (HARQ-IR) systems.
(13) Let G.sub.mother denote a kn polar code generator matrix of the mother code with lowest code rate r.sub.T, where n=k/r.sub.T. For given information bits (u.sub.1, . . . ,u.sub.k), the corresponding codeword for the lowest code rate r.sub.T is generated as:
(u.sub.1, . . . ,u.sub.k)G.sub.mother=(x.sub.1, . . . ,x.sub.n).
The codeword of a higher-rate code with code rate r.sub.i is simply obtained by taking the first n.sub.i=k/r.sub.i bits such as (x.sub.1, . . . ,x.sub.n.sub.
(14) In the present disclosure, a polar code generator matrix G.sub.mother (oftentimes referred to herein simply as a generator matrix G.sub.mother) is constructed of a rate-compatible polar code where each punctured polar code of a higher rate is also capacity achieving under a low-complexity Successive Cancellation (SC) decoding when code length n goes to infinity. As discussed below, the rate-compatible polar encoder 14 operates to encode k information bits according to a desired code rate according to the generator matrix G.sub.mother.
(15) In the following discussion, the generator matrix G.sub.mother is described with respect to an example of a rate-compatible polar code that can be used to encode k information bits and supports three code rates {r.sub.1,r.sub.2,r.sub.3}, where r.sub.1>r.sub.2>r.sub.3. This is then extended into a more general case with various rates {r.sub.1:i=1, . . . ,T}, where r.sub.1> . . . >r.sub.T.
(16) Let G.sub.N denote a generator matrix (which is also referred to herein as a polar code generator matrix) of polar code with code length N. G.sub.N is a deterministic matrix, as defined in E. Arikan, Channel Polarization: A Method for Constructing Capacity-Achieving Codes for Symmetric Binary-Input Memoryless Channels, IEEE Transactions on Information Theory, Vol. 55, Issue 7, pages 3051-3073. July 2009 (hereinafter Arikan). Specifically, let
(17)
Then, G.sub.N can be defined as G.sup..Math.n, where .Math.n denotes the n.sup.th Kronecker power and N=2.sup.n. A polar code with length N and rate r is completely defined by G.sub.N and an information set A with |A|=Nr. Here, the information set A determines the locations (i.e., rows of the generator matrix G.sub.N) to be used for the information bits in the input of polar encoding. The rows of the generator matrix G.sub.N that are not to be sued for the information bits are referred to as locations of frozen bits. Conversely, the rows of the generator matrix G.sub.N that are to be used for the information bits are referred to as locations of unfrozen bits or the locations of the information bits. Following the conventional notation of coding theory, a kN generator matrix of a polar code is also defined by simply taking the rows of G.sub.N corresponding to A, where all frozen bits are assumed to be zero. It is assumed that that the first k indices of A is again an information set of polar code of rate k/n, which can be easily obtained by ordering indices of A (see, for example, S. B. Korada, Polar Codes for Channel and Source Coding, PhD Thesis, cole Polytechnique Fdeale de Lausanne, 2009 (hereinafter Korada)). For a given information set A, G.sub.N.sup.A is defined as a row-permuted matrix of G.sub.N with the same size such that all rows of G.sub.N whose indices belong to A are located in the first |A| rows of G.sub.N.sup.A, i.e., the i-th row of G.sub.N.sup.A is equal to the A(i)-th row of G.sub.N, where A(i) denotes the i-th element of A. Notice that G.sub.N.sup.A is also a generator matrix of a polar code of length N. For an index subset D[1:N], G.sub.N.sup.A(D) denotes a submatrix of G.sub.N.sup.A consisting of rows whose indices belong to D.
(18) Letting k=r.sub.3n, one example of the kn generator matrix G.sub.mother has the form of:
(19)
where A.sub.1 denotes the information set of a polar code of code rate r.sub.1 and length
(20)
(21)
(22)
and where
(23)
(24) It can be confirmed that G.sub.mother is indeed the kn generator matrix since
r.sub.1n.sub.1=k and n.sub.1+n.sub.2+n.sub.3=n.
(25) For the convenience of notation, the above generator matrix G.sub.mother can be represented by
G.sub.mother=[S.sub.1S.sub.2S.sub.3]
Here, S.sub.i is a kn.sub.i matrix with
(26)
and
(27)
Notice that the information sets A.sub.1, A.sub.2, and A.sub.3 can be obtained from an efficient algorithm in I. Tal et al., How to Construct Polar Codes, IEEE Transactions on Information Theory, Vol. 59, Issue 10, Jul. 10, 2013, pages 6562-6582 (hereinafter Tal).
(28) In addition, a specific generator matrix can be defined for each punctured polar code (i.e., for each rate r.sub.i) as follows: rate r.sub.1: G.sub.r.sub.
Therefore, encoding and decoding for each of the code rates can be performed according to the above shortened matrices derived from the generator matrix G.sub.mother.
(29) Notably, in the example above, S.sub.1 can be used to encode all k information bits to provide n.sub.1 coded bits, S.sub.2 can be used to encode r.sub.2n.sub.2 of the k information bits (specifically, in this example, the last r.sub.2n.sub.2 bits of the k information bits) to provide n.sub.2 coded bits, and S.sub.3 can be used to encode r.sub.3n.sub.3 of the k information bits (specifically, in this example, the last r.sub.3n.sub.(3,2) bits of the k information bits and an additional subset of r.sub.3n.sub.(3,1) bits of the k information bits) to provide n.sub.3 coded bits. The coded bits resulting from S.sub.1 can be used to provide a code word for code rate r.sub.1, the concatenation of the coded bits resulting from S.sub.1 and S.sub.2 can be used to provide a code word for code rate r.sub.2, and the concatenation of the coded bits resulting from S.sub.1, S.sub.2 and S.sub.3 can be used to provide a code word for code rate r.sub.3.
(30) Importantly, S.sub.2 and S.sub.3 of the example generator matrix G.sub.mother above are only examples. In this example, S.sub.2 includes the polar code matrix G.sub.n.sub.
(31) In the example above, the generator matrix G.sub.mother is described with respect to an example having three code rates. However, more generally, given a sequence of rates {r.sub.i, i=1, . . . ,T} sorted in a descending order, i.e., r.sub.1>r.sub.2> . . . >r.sub.T, and k information bits to be communicated, the transmitter can transmit a sequence of polar codes to achieve each of these rates. Here, T is greater than or equal to 2. Following the expression in (1), the generator matrix G.sub.mother is represented by
G.sub.mother=[S.sub.1S.sub.2 . . . S.sub.T]
where S.sub.i is a kr.sub.in.sub.i matrix which can be obtained from the row-permuted generator matrix of i-th polar code denoted by G.sub.n.sub.
(32)
for i=1, . . . ,T, such that the total block length is given by
(33)
The number of unfrozen rows (bits) in the i-th polar code is given by
(34)
where
q.sub.j.sup.(i)=n.sub.j(r.sub.i1r.sub.i)
denotes the share of these unfrozen bits that is transmitted to convert the j-th polar code constructed previously (for 1j<i) from code rate r.sub.i1 to r.sub.i. Notice that in the previous process, the rate of the j-th polar code has been already converted into the code rate r.sub.i1. We define the locations of these n.sub.ir.sub.i unfrozen bits in G.sub.mother recursively as follows. Assume that we are given {G.sub.n.sub.0, define the interval
I.sub.j.sup.(i+1){Q.sub.j1.sup.(i+1)+1,Q.sub.j1.sup.(i+1)+2, . . . ,Q.sub.j1.sup.(i+1)+q.sub.j.sup.(i+1))}
where
(35)
for j=1, 2, . . . , i, such that {I.sub.j.sup.(i+1)}.sub.j=1.sup.i forms a partition of the integer set
(36)
The index mapping can now be defined as h.sup.(i+1): {1, 2, . . . , n.sub.i+1r.sub.i+1}.fwdarw.{1, 2, . . . , k} for S.sub.i+1 in a piece-wise fashion as
(37)
for m=1, 2, . . . , n.sub.i+1r.sub.i+1, where j.sub.m denotes the index of the interval I.sub.j.sub.
(38) An optional permutation mapping .sup.(i+1): {1, 2, . . . , n.sub.i+1r.sub.i+1}.fwdarw.{1, 2, . . . , n.sub.i+1r.sub.i+1} may also be combined with h.sup.(i+1)(m) to obtain
(39)
in order to allow different mappings of the unfrozen rows (or bits) of G.sub.n.sub.
(40) Now that the rate-compatible polar code generator matrix G.sub.mother has been described,
(u.sub.1, . . . ,u.sub.k)[S.sub.1S.sub.2]=(x.sub.1, . . . ,x.sub.n.sub.
In other words, the k information bits are encoded according to S.sub.1 to provide a first polar code (i.e., n.sub.1 coded bits in the form of a first polar code). The k information bits are also encoded according to S.sub.2 to provide a second polar code (i.e., n.sub.2 coded bits in the form of a second polar code). These first and second polar codes are concatenated to provide a polar code of length n.sub.1+n.sub.2. This polar code is the n.sub.1+n.sub.2 coded bits (i.e., the codeword) for code rate r.sub.2. The transmit node 12, and in particular the transmitter 16, transmits the coded bits (step 102).
(41)
(42) As illustrated in
(u.sub.1, . . . ,u.sub.k)S.sub.1=(x.sub.1, . . . ,x.sub.n.sub.
The polar encoder 24-2 encodes the k information bits (u.sub.1, . . . ,u.sub.k) for code rate r.sub.2 to provide n.sub.2 coded bits (x.sub.n.sub.
(u.sub.1, . . . ,u.sub.k)S.sub.2=(x.sub.n.sub.
Notably, as discussed above, due to the design of S.sub.2, only r.sub.2n.sub.2 of the k information bits (u.sub.1, . . . ,u.sub.k) are actually encoded by the polar encoder 24-2. Similarly, the polar encoder 24-3 encodes the k information bits (u.sub.1, . . . ,u.sub.k) for code rate r.sub.3 to provide n.sub.3 coded bits (x.sub.n.sub.
(u.sub.1, . . . ,u.sub.k)S.sub.2=(x.sub.n.sub.
Notably, as discussed above, due to the design of S.sub.3, only r.sub.3n.sub.3 of the k information bits (u.sub.1, . . . ,u.sub.k) are actually encoded by the polar encoder 24-3.
(43) In this example, the rate-compatible polar encoder 14 also includes a concatenator 26 that operates to concatenate the coded bits, or polar codes, output by the polar encoders 24-1 through 24-3 to provide the final coded bits, or codeword, output by the rate-compatible polar encoder 14. Note that, depending on the particular implantation, a desired code rate r.sub.1 can be achieved in different manners. For example, in one example embodiment, only the polar encoders 24 needed for the desired code rate r.sub.1 are active. For instance, if the desired code rate is r.sub.2 only the polar encoders 24-1 and 24-2 are active and, as a result, the output of the concatenator 26 consists of the coded bits (x.sub.1, . . . ,x.sub.n.sub.
(44)
(u.sub.1, . . . ,u.sub.k)G.sub.n.sub.
The polar encoder 24-2 encodes a subset of r.sub.2n.sub.2 of the k information bits (u.sub.1, . . . ,u.sub.k) for code rate r.sub.2 to provide n.sub.2 coded bits (x.sub.n.sub.
(u.sub.1, . . . ,u.sub.k)G.sub.n.sub.
Similarly, the polar encoder 24-3 encodes a subset of r.sub.3n.sub.3 bits of the k information bits (u.sub.1, . . . ,u.sub.k) for code rate r.sub.3 to provide n.sub.3 coded bits (x.sub.n.sub.
(u.sub.1, . . . ,u.sub.k)G.sub.n.sub.
Notably,
(45)
(46) In this example, the rate-compatible polar encoder 14 also includes a divider 30 that operates to divide the k information bits (u.sub.1, . . . ,u.sub.k) into appropriate subsets to be encoded by the polar encoders 28. In particular, in this example, the divider 30 provides all of the k information bits (u.sub.1, . . . ,u.sub.k) to the polar encoder 28-1, which then encodes the k information bits (u.sub.1, . . . ,u.sub.k) at the code rate r.sub.1 to provide the n.sub.1 coded bits (x.sub.1, . . . ,x.sub.n.sub.
(47) As discussed above with respect to the example of
(48) Thus far, the discussion has focused on the operation of the transmit node 12 and, in particular, the rate-compatible polar encoder 14.
(49) A description of the decoding process for a specific case for T=3 is as follows. The extension of this process to the general case is straightforward. For the case where T=3, there are three polar codes whose generator matrices are G.sub.n.sub.
Using this procedure, two polar decoding iterations result in successful decoding of (r.sub.1r.sub.2)n.sub.1+r.sub.2n.sub.1=k information bits. Notice that in the two decoding iterations, two polar codes of code rate r.sub.2 are used. Since both achieve the capacity as n goes to infinity, the proposed code can also achieve the capacity.
(50) In the above, a sequential decoding process is described where information bits are decoded by two polar codes sequentially. This approach is optimal by achieving the capacity, when code length goes to infinity. Yet, for a finite code length, other decoding algorithms can be considered such as Belief Propagation (BP) decoding over whole graph induced by two parallel concatenated polar codes.
(51) Next, the decoding procedure is described for code rate r.sub.3. In a manner similar to that described above, three sequential polar decoding operations are used to decode the information bits, where, in this example, all polar codes (used in decoding) are of code rate r.sub.3. First, the r.sub.3n.sub.3 information bits encoded for code rate r.sub.3 (as described above) are decoded using the polar code of code rate r.sub.3 and with generator matrix G.sub.n.sub.
(52) In other words, the successive decoding procedure can be explained as follows. Assuming that the sequential decoding procedure begins with code rate r.sub.T (but may alternatively start at any desired code rate r.sub.d), the subset of information bits carried by the n.sub.T coded bits at the code rate r.sub.T (e.g., the last retransmission in the case of HARQ-IR) is first decoded. The resulting decoded information bits are used as frozen bits to decode the subset of the information bits carried by the n.sub.T1 coded bits. Notably, this stage of polar coding/decoding is originally designed for code rate r.sub.T1, but due to the use of the previously decoded information bits as frozen bits, the code rate of this polar decoding is effectively reduced to r.sub.T as well. Then, the union of the two sets of information bits resulting from the two previous polar decodes is used as frozen bits for the next stage of polar decoding, where the subset of information bits carried by the n.sub.T2 coded bits are decoded. This stage of polar decoding is originally designed for code rate r.sub.T2, but due to the use of the previously decoded information bits as frozen bits, the code rate of this polar decoding is effectively reduced to r.sub.T as well. The process continues in this manner until all of the information bits have been decoded.
(53)
(54) As illustrated in
(55) In
(56) As one example, encoding and decoding can be performed as follows. This is only an example and is not to be construed as limiting the scope of the present disclosure. Consider a rate-compatible polar code with 3.Math.2.sup.m (for some positive integer m) information bits (i.e., k=3.Math.2.sup.m) and code rates (3/4, 1/2, 1/4) (i.e., {r.sub.i|i=1, . . . ,3}={3/4, 1/2, 1/4}). For the encoding, the following polar codes may be employed by the polar encoders 24, 28: Encoder 1 (polar encoder 24-1, 28-1): polar code of code rate 3/4 and length 2.sup.m+2; Encoder 2 (polar encoder 24-2, 28-2): polar code of code rate 1/2 and length 2.sup.m+1; and Encoder 3 (polar encoder 24-3, 28-3): polar code of code rate 1/4 and length 2.sup.m+2.
For the decoding, the following polar codes can be employed by the polar decoders 32: code rate 3/4: polar decoder (polar decoder 32-1) of code rate 3/4 and length 2.sup.m+2; code rate 1/2: using two polar codes: Decoder 1: polar decoder (polar decoder 32-2) of code rate 1/2 and length 2.sup.m+1; and Decoder 2: polar decoder (polar decoder 32-1) of code rate 1/2 and length 2.sup.m+2; and code rate 1/4: using three polar codes in
(57) The transmit node 12 and the receive node 18 described above may be implemented in any suitable type of wireless communications system 10. In this regard,
(58) In this example, the cellular communications network 36 is a Long Term Evolution (LTE) network and, as such, LTE terminology is sometimes used. However, the cellular communications network 36 is not limited to LTE. As illustrated, the cellular communications network 36 includes a Evolved Universal Terrestrial Radio Access Network (EUTRAN) 38 including enhanced or evolved Node Bs (eNBs) 40 (which may more generally be referred to herein as base stations) serving corresponding cells 42. User Equipment devices (UEs) 44 (which may more generally be referred to herein as wireless devices) transmit signals to and receive signals from the eNBs 40. The eNBs 40 communicate with one another via an X2 interface. Further, the eNBs 40 are connected to a Evolved Packet Core (EPC) 46 via S1 interfaces. As will be understood by one of ordinary skill in the art, the EPC 46 includes various types of core network nodes such as, e.g., Mobility Management Entities (MMEs) 48, Serving Gateways (S-GWs) 50, and Packet Data Network Gateways (P-GWs) 52.
(59) In some embodiments, the transmit node 12 is the eNB 40 and the receive node 18 is the UE 44. In other embodiments, the transmit node 12 is the UE 44 and the receive node 18 is the eNB 40. In other words, the eNBs 40 may include the rate-compatible polar encoder 14 and the transmitter 16 of the transmit node 12 of
(60) As mentioned above, the generator matrix G.sub.mother described above can be utilized for HARQ-IR. In this regard,
(61) Upon receiving the HARQ NACK, the eNB 40 selects a new code rate for a HARQ, or more specifically HARQ-IR, retransmission (step 410) and performs polar encoding of the downlink data (i.e., the k information bits) to provide the additional coded bits to transform the coded bits for the initial code rate into coded bits for the new code rate (step 412). For example, if the initial code rate is r.sub.1 and the new code rate is r.sub.2, then the polar encoding of step 412 encodes the r.sub.2n.sub.2 information bits using the generator matrix G.sub.n.sub.
(62) In this example, the UE 44 attempts decoding using the additional coded bits received in step 414 (step 416). In particular, the UE 44 performs sequential polar decoding of the r.sub.in.sub.i information bits starting at the new code rate, as described above with respect to
(63)
(64) In some embodiments, a computer program including instructions which, when executed by at least one processor, causes the at least one processor to carry out at least some of the functionality of the rate-compatible polar encoder 14 and/or the rate-compatible polar decoder 20 according to any of the embodiments described herein is provided. In some embodiments, a carrier containing the aforementioned computer program product is provided. The carrier is one of an electronic signal, an optical signal, a radio signal, or a computer readable storage medium (e.g., a non-transitory computer readable medium such as the memory 58).
(65) The following acronyms are used throughout this disclosure.
(66) TABLE-US-00001 5G 5.sup.th Generation ACK Acknowledgement ASIC Application Specific Integrated Circuit BP Belief Propagation CPU Central Processing Unit CRC Cyclic Redundancy Check eNB Enhanced or Evolved Node B EPC Evolved Packet Core EUTRAN Evolved Universal Terrestrial Radio Access Network FPGA Field Programmable Gate Array HARQ Hybrid Automatic Repeat Request HARQ-IR Hybrid Automatic Repeat Request based on Incremental Redundancy IR Incremental Redundancy LDPC Low-Density Parity-Check LTE Long Term Evolution ML Maximum-Likelihood MME Mobility Management Entity NACK Negative Acknowledgement P-GW Packet Data Network Gateway RAN Radio Access Network RX Receive SC Successive Cancellation SCL Successive Cancellation List S-GW Serving Gateway TX Transmit UE User Equipment
(67) Those skilled in the art will recognize improvements and modifications to the embodiments of the present disclosure. All such improvements and modifications are considered within the scope of the concepts disclosed herein and the claims that follow.