Embodiments of the present invention relate to the fields of electronic and communications technologies, and more specifically, to data encoding and decoding methods and apparatuses.
In a communications system, an encoding technology is usually used to improve data transmission reliability and ensure communication quality. A polar code (English translation: Polar code) algorithm is theoretically proved to be the first encoding and decoding algorithm that can achieve a Shannon capacity and has low coding-decoding complexity (coding-decoding complexity is O(N log N)).
Currently, in an encoding process using the polar code algorithm, how to construct a data block at a specific aggregation level to match a specific rate is a problem urgently needing to be resolved at present.
Embodiments of the present invention provide data encoding and decoding methods and apparatuses, to construct a data block at a specific aggregation level in an encoding process using a polar code algorithm, so as to match a specific rate.
According to a first aspect, a data encoding method is provided. The method includes:
receiving a to-be-encoded data block;
encoding the data block at an aggregation level of 2L, where a formula used during the encoding is as follows:
where {dot over (u)}L={uL uL−1 . . . u1}, {dot over (u)}2L={u2L u2L−1 . . . uL+1}, ċL={cL cL−1 . . . c1}, ċ2L={c2L c2L−1 . . . cL+1}, GLN=GN⊗ log
outputting the encoded data block.
In the embodiment of the data encoding method, in the encoding formula, {dot over (u)}L={uL uL−1 . . . u1}, and {dot over (u)}2L={u2L u2L−1 . . . uL+1}. It can be learned that, a data block to be encoded at a higher aggregation level is nested with a data block to be encoded at a lower aggregation level. In this way, in a decoding process, after the data block to be encoded at the lower aggregation level that is nested in the data block to be encoded at the higher aggregation level is decoded, an information bit carried in the data block to be encoded at the higher aggregation level is already decoded. Therefore, it is unnecessary to continue the decoding, thereby effectively reducing a decoding delay and stopping the decoding early.
In a first possible implementation of the first aspect, values in X bits in {dot over (u)}L are the same as values in X bits in {dot over (u)}2L, information in at least one bit in {dot over (u)}2L except the X bits is a frozen bit and/or a check frozen bit, and X is a natural number greater than 0.
In the embodiment of the data encoding method, there are K information bits in {dot over (u)}L, values in X bits in the K information bits are the same as the values in the X bits in {dot over (u)}2L, X≤K, X is a natural number greater than 0, and information in the X bits in {dot over (u)}L is a check frozen bit. In this way, in an encoding process, a result of encoding a group of data blocks at a higher aggregation level is different from a result of encoding the group of data blocks at a lower aggregation level, bringing an encoding gain. In this way, in the embodiment of the data encoding method, when the aggregation level is greater than 1, there may be a full encoding gain caused by an increase in a code length and a decrease in a code rate.
With reference to the first aspect or the first possible implementation of the first aspect, in a second possible implementation, information in all bits in {dot over (u)}2L except the X bits is a frozen bit and/or a check frozen bit.
With reference to any one of the first aspect or the first and second possible implementations of the first aspect, in a third possible implementation, the X bits in {dot over (u)}2L are located in any positions in {dot over (u)}2L, and the X bits in {dot over (u)}L are located in any positions in {dot over (u)}L.
With reference to any one of the first aspect or the first to third possible implementations of the first aspect, in a fourth possible implementation, polarization channel reliability at positions of the X bits in {dot over (u)}2L is higher than or equal to reliability at positions of the X bits in {dot over (u)}L, and the polarization channel reliability is a polarization weight of each polarization channel.
An information bit at a position with lower reliability in {dot over (u)}L and an information bit at a position with higher reliability in {dot over (u)}2L are repeated, to ensure to the greatest extent that the duplicated information bit is still located at a position with relatively high reliability, thereby obtaining an encoding gain.
With reference to any one of the first aspect or the first to fourth possible implementations of the first aspect, in a fifth possible implementation, a value in at least one bit in at least one of data blocks u with subscripts greater than 1 is the same as a value in at least one bit storing a check frozen bit in a data block u1.
With reference to any one of the first aspect or the first to fifth possible implementations of the first aspect, in a sixth possible implementation, there are a total of K information bits in {dot over (u)}L and {dot over (u)}2L, K is a natural number greater than 0, X≤K<N, and N indicates a length of an encoded mother code when L=1.
With reference to any one of the first aspect or the first to sixth possible implementations of the first aspect, in a seventh possible implementation, information in the X bits in {dot over (u)}L is a check frozen bit.
According to a second aspect, an embodiment of the present invention further provides a data decoding method, including: receiving LLR (Log-likelihood ratio, log-likelihood ratio) information corresponding to some encoded data blocks at an aggregation level of 2L, where the some encoded data blocks are data blocks that are encoded at an aggregation level lower than 2L, L=2n, and n is a natural number greater than or equal to 0;
decoding the LLR information at the aggregation level lower than 2L; and
outputting a decoding result of the LLR information.
In the embodiment of the data decoding method, K information bits are also carried; when encoding is performed at different aggregation levels, a receive end (for example, a terminal) performs decoding at a lower aggregation level first, and when the decoding succeeds at the lower aggregation level, does not need to read an LLR at a higher aggregation level for decoding, thereby effectively reducing a decoding delay and stopping the decoding early. Further, based on the data decoding method in this embodiment of the present invention, even if the data block is encoded at the aggregation level of 2L, decoding may succeed at an aggregation level of L or even lower. In this way, in a decoding process, it is unnecessary to traverse all possible aggregation levels for detection. Therefore, a quantity of blind detection is effectively reduced.
In a first possible implementation of the second aspect, the encoded data block at the aggregation level of 2L is obtained by encoding a data block at the aggregation level of 2L.
With reference to the second aspect or the first possible implementation of the second aspect, in a second possible implementation, the data block that is encoded at the aggregation level lower than 2L is obtained by encoding a data block at the aggregation level lower than 2L.
With reference to any one of the second aspect or the first and second possible implementations of the second aspect, in a third possible implementation, the decoding the LLR information at the aggregation level lower than 2L includes:
decoding the LLR information corresponding to the data block that is encoded at the aggregation level lower than 2L.
With reference to any one of the second aspect or the first to third possible implementations of the second aspect, in a fourth possible implementation, the decoding result includes an original data block before the data block is encoded at the aggregation level lower than 2L.
With reference to any one of the second aspect or the first to fourth possible implementations of the second aspect, in a fifth possible implementation, the decoding result includes decoded data blocks {dot over (u)}L and {dot over (u)}2L, L, {dot over (u)}L={uL uL−1 . . . u1}, {dot over (u)}2L={u2L u2L−1 . . . uL+1}, u with a subscript indicates a to-be-encoded data block, the subscript of u indicates an order in which the to-be-encoded data block is arranged based on a polar construction sequence, values in X bits in {dot over (u)}L are the same as values in X bits in {dot over (u)}2L, information in at least one bit in {dot over (u)}2L except the X bits is a frozen bit and/or a check frozen bit, and X is a natural number greater than 0.
With reference to any one of the second aspect or the first to fifth possible implementations of the second aspect, in a sixth possible implementation, there are a total of K information bits in {dot over (u)}L and {dot over (u)}2L, K is a natural number greater than 0, X≤K<N, and N indicates a length of an encoded mother code when L=1.
With reference to any one of the second aspect or the first to sixth possible implementations of the second aspect, in a seventh possible implementation, information in the X bits in {dot over (u)}L is a check frozen bit.
Another aspect of the embodiments of this application further provides Embodiment 1 of an encoder, including an interface module and an encoding module, where the interface module is configured to receive a to-be-encoded data block;
the encoding module is configured to encode the data block at an aggregation level of 2L, where a formula used during the encoding is as follows:
where {dot over (u)}L={uL uL−1 . . . u1}, {dot over (u)}2L={u2L u2L−1 . . . uL+1}, ċL={cL cL−1 . . . c1}, ċ2L={c2L c2L−1 . . . cL+1}, GLN=GN⊗ log
the interface module is further configured to output the encoded data block.
The encoder provided in this embodiment of the present invention may be configured to perform various embodiments of the data encoding method, and implementation principles and technical effects of the encoder and the data encoding method are similar. Details are not described herein again.
Another aspect of the embodiments of this application further provides Embodiment 2 of an encoder, including at least one circuit board, and a processor, a memory, and a bus that are disposed on the at least one circuit board, where the processor is connected to the memory by using the bus, and when the encoder is operating, the processor reads and executes an instruction in the memory or runs a hardware logical circuit of the processor, so that the encoder performs various embodiments of the data encoding method.
In an optional implementation, in Embodiment 2 of the encoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
Another aspect of the embodiments of this application further provides Embodiment 3 of an encoder, including at least one circuit board, and a processor, a memory, and a bus that are disposed on the at least one circuit board, where the processor is connected to the memory by using the bus, and when Embodiment 3 of the encoder is operating, the processor reads and executes an instruction in the memory or runs a hardware logical circuit of the processor, so that Embodiment 3 of the encoder implements functions in various implementations of the interface module and the encoding module in Embodiment 1 of the encoder.
In an optional implementation, in Embodiment 3 of the encoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
Another aspect of the embodiments of this application further provides Embodiment 1 of a decoder, including a transceiver module and a decoding module, where the transceiver module is configured to receive LLR information corresponding to some encoded data blocks at an aggregation level of 2L, where the some encoded data blocks are data blocks that are encoded at an aggregation level lower than 2L, L=2n, and n is a natural number greater than or equal to 0;
the decoding module is configured to decode the LLR information at the aggregation level lower than 2L; and
the transceiver module is further configured to output a decoding result of the LLR (Log-likelihood ratio, log-likelihood ratio) information.
Embodiment 1 of the decoder provided in this embodiment of the present invention may be configured to perform various embodiments of the data decoding method, and implementation principles and technical effects of the decoder and the data decoding method are similar. Details are not described herein again.
Another aspect of the embodiments of this application further provides Embodiment 2 of a decoder, including at least one circuit board, and a processor, a memory, and a bus that are disposed on the at least one circuit board, where the processor is connected to the memory by using the bus, and when Embodiment 2 of the decoder is operating, the processor reads and executes an instruction in the memory or runs a hardware logical circuit of the processor, so that the decoder performs various embodiments of the data decoding method.
In an optional implementation, in Embodiment 2 of the decoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
Another aspect of the embodiments of this application further provides Embodiment 3 of a decoder, including at least one circuit board, and a processor, a memory, and a bus that are disposed on the at least one circuit board, where the processor is connected to the memory by using the bus, and when Embodiment 3 of the decoder is operating, the processor reads and executes an instruction in the memory or runs a hardware logical circuit of the processor, so that Embodiment 3 of the decoder implements various implementations of functions of the transceiver module and the decoding module in Embodiment 1 of the decoder.
In an optional implementation, in Embodiment 3 of the decoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
Another aspect of the embodiments of this application further provides a computer-readable storage medium, where the computer-readable storage medium stores an instruction, and when the instruction is running on a computer, the computer is enabled to perform the methods according to the foregoing aspects.
Another aspect of the embodiments of this application further provides a computer program product including an instruction, where when the computer program product is running on a computer, the computer is enabled to perform the methods according to the foregoing aspects.
A data block constructed through encoding using a polar code algorithm is a linear block code. A matrix used during encoding is GN, and an encoding process of a polar code is x1N=u1NGN, where u1N={m1, m2, . . . , mN} u1N is a binary row vector having a length of N, to be specific, a code length is N, GN is an N×N matrix, GN=F2⊗(log
and F2⊗(log
In the encoding process using the polar code algorithm, some bits in u1N are used to carry information, and are referred to as information bits, and a set of indexes of the information bits is represented by A. The other bits are set to constant values that are pre-agreed on by a transmit end and a receive end, and are referred to as fixed bits or frozen bits, and a set of indexes of the constant bits is represented by a complementary set Ac of A. Without loss of generality, these constant bits are usually set to 0, and the constant bits may be randomly set. In this way, an output of the encoding using the polar code algorithm may be simplified as: x1N=uAGN(A) where uA is a set of information bits in u1N, uA is a row vector having a length of K, to be specific, |A|=K, |⋅| indicates a quantity of elements in the set, K is a quantity of the information bits, GN(A) is a sub matrix obtained by using rows corresponding to the indexes in the set A in the matrix GN, and GN(A) is a K×N matrix.
As shown in
The polar code algorithm is based on a channel polarization (English translation: Channel Polarization) phenomenon, to obtain, by using a constructive encoding method, a data block approximating a channel capacity. Common construction methods include a method for calculating polarization channel reliability that includes density evolution (English translation: density evolution, DE for short), Gaussian approximation (English translation: Gaussian approximation, GA for short), linear fitting, a polarization weight, and other methods. In the encoding process using the polar code algorithm, a process of selecting the set A determines, to some extent, performance of a data block that is encoded by using the polar code algorithm. It can be learned from the coding matrix that, a code length of the data block that is encoded by using the polar code algorithm is an integer power of 2.
Compared with a conventional polar code and a CRC (Cyclic Redundancy Check, cyclic redundancy check) auxiliary polar code, a PC (Parity-Check) polar code has a larger code distance and better BLER (Block Error Rate) performance when an SCL (Successive Cancellation List) decoding algorithm is used, and therefore has better application potential. For the PC polar code, before polar encoding is performed, check precoding is first performed on an information bit. A precoding process is briefly described as follows: A check equation is an equation that associates an information bit with a check bit. If the check equation is represented in a form of a vector, the last one of members of the check equation is a check bit. A value of the check bit is addition modulo 2 of other members of the check equation. For example, if the check equation is [1 3 5 7], the subchannels 1, 3 and 5 are information subchannels. If values of the subchannels are respectively m1, m3, m5, the value of the check bit is m2=mod(m1+m3+m5,2).
The foregoing various polar codes such as the PC polar code and the CRC polar code are all applicable to the embodiments of the present invention.
As shown in
S101. Receive a to-be-encoded data block.
S102. Encode the data block at an aggregation level of 2L, where a formula used during the encoding is as follows:
where {dot over (u)}L={uL uL−1 . . . u1}, {dot over (u)}2L={u2L u2L−1 . . . uL+1}, ċL={cL cL−1 . . . c1}, ċ2L={c2L c2L−1 . . . cL+1}, GLN=GN⊗ log
S103. Output the encoded data block.
In the embodiment of the data encoding method, each aggregation level is a power of 2.
In the embodiment of the data encoding method, in an encoding process at a particular aggregation level, in the foregoing encoding formula, ċL={cL cL−1 . . . c1}, and ċ2L={c2L c2L−1 . . . cL+1}. It can be learned that, a data block that is encoded at a higher aggregation level includes a data block that is encoded at a lower aggregation level; or it may be considered that a data block that is encoded at a higher aggregation level is nested with a data block that is encoded at a lower aggregation level. It can be more clearly learned by listing cases of different values of L that when the aggregation level is 1, u1GN=c1. When the aggregation level is 2, to be specific, when L=1,
When the aggregation level is 4, to be specific, when L=2,
In the encoding process, a higher aggregation level that is used indicates a lower code rate. It can be learned from {dot over (u)}L={uL uL−1 . . . u1}, and {dot over (u)}2L={u2L u2L−1 . . . uL+1} that, at least one data block to be encoded at a higher aggregation level is nested with at least one data block to be encoded at a lower aggregation level, and correspondingly, at least one data block that is encoded at a higher aggregation level is nested with at least one data block that is encoded at a lower aggregation level. It may also be understood that, the at least one data block to be encoded at the lower aggregation level is a subset of the at least one data block to be encoded at the higher aggregation level. In a process of decoding the at least one encoded data block, after the at least one data block to be encoded at the lower aggregation level that is nested in the at least one data block to be encoded at the higher aggregation level is decoded, an information bit carried in the at least one data block to be encoded at the higher aggregation level is already decoded. Therefore, it is unnecessary to continue the decoding, thereby effectively reducing a decoding delay and stopping the decoding early.
When being encoded at different aggregation levels, the to-be-encoded data block is described as follows.
In the embodiment of the data encoding method, values in X bits in {dot over (u)}L are the same as values in X bits in {dot over (u)}2L, information in at least one bit in {dot over (u)}2L except the X bits is a frozen bit and/or a check frozen bit, and X is a natural number greater than 0.
In the embodiment of the data encoding method, there are a total of K information bits in {dot over (u)}L and {dot over (u)}2L, K is a natural number greater than 0, X≤K<N, and N indicates a length of an encoded mother code when L=1.
In the embodiment of the data encoding method, information in the X bits in {dot over (u)}L is a check frozen bit.
In the embodiment of the data encoding method, a value in at least one bit in at least one of data blocks u with subscripts greater than 1 is the same as a value in at least one bit storing a check frozen bit in a data block u1. For example, a data block u with a subscript greater than 1 may be any one or more of u2, u3, u4, u5, u6, u7, and u8.
In the embodiment of the data encoding method, information in all bits in {dot over (u)}2L except the X bits is a frozen bit and/or a check frozen bit.
In the embodiment of the data encoding method, the X bits in {dot over (u)}2L are located in any positions in {dot over (u)}2L, and the X bits in {dot over (u)}L are located in any positions in {dot over (u)}L.
In the embodiment of the data encoding method, polarization channel reliability at positions of the X bits in {dot over (u)}2L is higher than or equal to reliability at positions of the X bits in {dot over (u)}L, and the polarization channel reliability is a polarization weight of each polarization channel.
Calculating polarization weights (reliability) of N polarization channels includes:
calculating polarization weights Wi of the N polarization channels according to the following formula, to obtain a first polarization weight vector:
where i≐Bn−1Bn−2 . . . B0, i is a channel index, Bn−1Bn−2 . . . B0 is a binary representation of i, Bn−1 is the most significant bit, B0 is the least significant bit, Bj∈{0,1}, j∈{0, 1, . . . , n−1}, i∈{0, 1, . . . , n−1}, N=2n, ϕ is a target code length based on first data transmission, α is a parameter preset for a code rate of the first data transmission, and n is a positive integer.
An information bit at a position with lower reliability in {dot over (u)}L and an information bit at a position with higher reliability in {dot over (u)}2L are repeated, to ensure to the greatest extent that the duplicated information bit is still located at a position with relatively high reliability, thereby bringing an encoding gain. In this way, in a process of transferring the encoded data block, because of the lower reliability, the information bit at the position with the lower reliability in {dot over (u)}L is easily lost, while the information bit at the position with the higher reliability in {dot over (u)}2L is not easily lost. In this way, in the decoding process, even if the information bit at the position with the lower reliability in {dot over (u)}L is lost, a same bit can be found from the information bit at the position with the higher reliability in {dot over (u)}2L, thereby obtaining a complete information bit after the decoding.
In the embodiment of the data encoding method, specifically, u indicates a to-be-encoded data block, u with a subscript of “1” indicates a data block ranked first in a construction sequence of a group of to-be-encoded data blocks according to a PC-polar encoding method; u with a subscript of “2L” indicates a data block ranked 2Lth; u with a subscript of “2L−1” indicates a data block ranked (2L−1)th; u with a subscript of “L+1” indicates a data block ranked (L+1)th; u with a subscript of “L” indicates a data block ranked Lth; and u with a subscript of “L−1” indicates a data block ranked (L−1)th; c indicates an encoded data block; c with a subscript of “1” indicates a data block obtained by encoding the data block u1; c with a subscript of “2L” indicates a data block obtained by encoding data blocks {u1, u2, . . . , u2L−1, u2L}; c with a subscript of “2L−1” indicates a data block obtained by encoding data blocks {u1, u2, . . . , u2L−1}; c with a subscript of “L+1” indicates a data block obtained by encoding data blocks {u1, u2, . . . , uL, uL+1}; c with a subscript of “L” indicates a data block obtained by encoding data blocks {u1, u2, . . . , uL−1, uL}; and c with a subscript of “L−1” indicates a data block obtained by encoding data blocks {u1, u2, . . . , uL−2, uL−1}.
In the embodiment of the data encoding method, the ellipsis “ . . . ” in {uL uL 1 . . . u1} indicates omission of u with consecutive subscripts between {dot over (u)}L−1 and u1, and when L=2, “ . . . ” may be ignored because {dot over (u)}L−1 and u1 are the same, and there is no omissible part in the middle.
The ellipsis “ . . . ” in {u2L u2L 1 . . . uL|1} indicates omission of u with consecutive subscripts between {dot over (u)}2L−1 and {dot over (u)}L+1, and when L=2, “ . . . ” may be ignored because {dot over (u)}2L−1 and {dot over (u)}L+1 are the same, and there is no omissible part in the middle.
The ellipsis “ . . . ” in {cL cL−1 . . . c1} indicates omission of c with consecutive subscripts between cL−1 and c1, and when L=2, “ . . . ” may be ignored because cL−1 and c1 are the same, and there is no omissible part in the middle.
The ellipsis “ . . . ” in {c2L c2L−1 . . . cL+1} indicates omission of c with consecutive subscripts between c2L−1 and cL+1, and when L=2, “ . . . ” may be ignored because c2L−1 and cL+1 are the same, and there is no omissible part in the middle.
In the embodiment of the data encoding method, the values in the X bits in {dot over (u)}L are the same as the values in the X bits in {dot over (u)}2L. It may be considered that the values in the X bits in {dot over (u)}2L are duplicated from the X bits in {dot over (u)}L.
In the embodiment of the data encoding method, there are K information bits in {dot over (u)}L, values in X bits in the K information bits are the same as the values in the X bits in {dot over (u)}2L, X≤K, X is a natural number greater than 0, and information in the X bits in {dot over (u)}L is a check frozen bit. For example, values in X bits at positions with lower reliability in {dot over (u)}L are the same as the values in the X bits in {dot over (u)}2L, a value of X is at least 1, and a maximum value is a quantity K of all information bits. In this way, in the encoding process, a result of encoding a group of data blocks at a higher aggregation level is different from a result of encoding the group of data blocks at a lower aggregation level, so that there is an encoding gain. In this way, in the embodiment of the data encoding method, when the aggregation level is greater than 1, there may be a full encoding gain caused by an increase in a code length and a decrease in a code rate.
In the embodiment of the data encoding method, English translation of the check frozen bit refers to a parity-check frozen bit or PC-frozen.
The embodiment of the data encoding method may be performed by an eNodeB (English translation: eNodeB), and may be specifically performed by an encoder in the eNodeB. The eNodeB determines, based on a factor such as channel quality, an aggregation level used by a PDCCH (Physical Downlink Control Channel, physical downlink control channel). For example, if the PDCCH is sent to UE (user equipment, user equipment) with very good downlink channel quality (for example, located in the center of a cell), one CCE (Control Channel Element, control channel element) may be sufficient for sending the PDCCH. If the PDCCH is set to UE with very poor downlink channel quality (for example, located on the edge of a cell), eight CCEs may need to be used to send the PDCCH, to achieve sufficient robustness. A higher aggregation level indicates a lower code rate.
As shown in
When the AL=1, where the AL is short for Aggregation Level, and Chinese translation is aggregation level, a mother code length N of the to-be-encoded data block u1 is equal to four bits, and the quantity K of information bits is 3. When the AL=2, a total mother code length of the to-be-encoded data blocks u1 and u2 is 2*N=8 bits, X is 1, the third information bit in u1 is duplicated to a position with highest reliability in u2, a PC-F bit is set at a position of the third information bit in u1, the PC-F bit is used as a check bit, and the PC-F bit has a same value as the duplicated information bit. When the AL=4, a total mother code length of the to-be-encoded data blocks u1, u2, u3, and u4 is 16 bits, X is 2, the first and second information bits in u1 are respectively duplicated to positions with highest reliability in u3 and u4, and PC-F bits are set at positions of the first and second information bits in u1.
As shown in
S201. Receive LLR information corresponding to some encoded data blocks at an aggregation level of 2L, where the some encoded data blocks are data blocks that are encoded at an aggregation level lower than 2L, L=2n, and n is a natural number greater than or equal to 0.
S202. Decode the LLR information at the aggregation level lower than 2L.
S203. Output a decoding result of the LLR (Log-likelihood ratio, log-likelihood ratio) information.
In the embodiment of the data decoding method, K information bits are also carried; when encoding is performed at different aggregation levels, a receive end (for example, a terminal) performs decoding at a lower aggregation level first, and when the decoding succeeds at the lower aggregation level, does not need to read an LLR at a higher aggregation level for decoding, thereby effectively reducing a decoding delay and stopping the decoding early.
If the decoding fails, an LLR at a higher aggregation level is further read for decoding.
In the embodiment of the data decoding method, a data block that is encoded at the aggregation level of 2L is nested with a data block that is encoded at the aggregation level lower than 2L. It should be noted that, the encoded data block is obtained through encoding. In an encoding process, the encoding may be performed at the aggregation level of 2L, or the encoding may be performed at the aggregation level lower than 2L, and a value of the aggregation level used for the encoding is a power of 2. In the embodiment of the data decoding method, a receive end does not know an aggregation level at which the encoded data block corresponding to the received LLR information is encoded. Therefore, this is a blind detection process. Decoding starts when a set of LLR information is received, and encoded data blocks corresponding to the set of LLR information may be only some of a group of encoded data blocks sent by a transmit end. For example, the encoded data blocks corresponding to the received set of LLR information are encoded at an aggregation level of L, and the group of encoded data blocks sent by the transmit end are encoded at the aggregation level of 2L.
The receive end does not know an aggregation level at which the transmit end performs encoding, and therefore, may attempt to perform decoding from a low aggregation level, for example, attempt to perform decoding at an aggregation level of 1 first, and then perform decoding at an aggregation level of 2. An attempted aggregation level is constantly increasing. Certainly, the receive end may also attempt to perform decoding at the aggregation level of 2 first.
In the embodiment of the data decoding method, when an encoder side uses the aggregation level of 2L in an encoding process, the receive end may perform decoding when receiving LLR information corresponding to a data block that is encoded at the aggregation level lower than 2L, and if decoding the LLR information succeeds, outputs a decoding result. The decoding result includes: a state of the data block before encoding of the data block that is encoded at the aggregation level lower than 2L, namely, an original data block before the data block is encoded at the aggregation level lower than 2L, and may further include an information bit carried in the decoded data block. In this way, remaining LLR information is not required for decoding. Based on the data decoding method in this embodiment of the present invention, even if the data block is encoded at the aggregation level of 2L, decoding may succeed at an aggregation level of L or even lower. In this way, in a decoding process, it is unnecessary to traverse all possible aggregation levels for detection. Therefore, a quantity of blind detection is effectively reduced.
In the embodiment of the data decoding method, the encoded data block at the aggregation level of 2L is obtained by encoding a data block at the aggregation level of 2L.
In the embodiment of the data decoding method, the data block that is encoded at the aggregation level lower than 2L is obtained by encoding a data block at the aggregation level lower than 2L.
In the embodiment of the data decoding method, the LLR information corresponding to the encoded data block is obtained from the encoded data block. For example, the LLR information is obtained through processes of modulating the encoded data block and transmitting the encoded data block through a channel.
In the embodiment of the data decoding method, the decoding the LLR information at the aggregation level lower than 2L includes:
decoding the LLR information corresponding to the data block that is encoded at the aggregation level lower than 2L.
The embodiment of the data decoding method is implemented to obtain through decoding a data block before the data block is encoded in the embodiment of the data encoding method. Therefore, the formulas, meanings, and values of various parameters in the formulas, and specific implementations of the data decoding method and the data encoding method mutually correspond, and can be mutually referenced. In the embodiment of the data decoding method in the present invention, an LLR corresponding to a lower aggregation level of ċL is first received for decoding. When the LLR corresponding to the lower aggregation level of ċL is decoded successfully, it is not necessary to continue to decode an LLR corresponding to ċ2L.
In the embodiment of the data decoding method, the decoding result includes decoded {dot over (u)}L and {dot over (u)}2L, {dot over (u)}L={uL uL−1 . . . u1}, {dot over (u)}2L={u2L u2L−1 . . . uL+1}, u with a subscript indicates a to-be-encoded data block, the subscript of u indicates an order in which the to-be-encoded data block is arranged based on a polar construction sequence, values in X bits in {dot over (u)}L are the same as values in X bits in {dot over (u)}2L, information in at least one bit in {dot over (u)}2L except the X bits is a frozen bit and/or a check frozen bit, and X is a natural number greater than 0.
In the embodiment of the data decoding method, there are a total of K information bits in {dot over (u)}L and {dot over (u)}2L, K is a natural number greater than 0, X≤K<N, and N indicates a length of an encoded mother code when L=1.
In the embodiment of the data decoding method, information in the X bits in {dot over (u)}L is a check frozen bit.
Check frozen bits in the X bits in are in a one-to-one corresponding check relationship with information bits in the X bits. For example, it may be understood that, each check frozen bit in the X bits in corresponds to one information bit in the X bits in, and the two bits may be checked according to a check equation.
The embodiment of the data decoding method may be performed by UE (user equipment, user equipment), for example, performed by a terminal, and may be specifically performed by a decoder in the UE. It can be learned from the embodiment of the data decoding method that, in the decoding process, the decoding may be performed at a lower aggregation level first, to be specific, an LLR corresponding to the lower aggregation level is received for decoding, and if decoding the LLR succeeds, it is unnecessary to read an LLR (Log-likelihood ratio, log-likelihood ratio) at a higher aggregation level, thereby reducing a decoding delay and stopping the decoding early. When the terminal is not clear about a current aggregation level and can perform only blind detection, the terminal may perform decoding at a lower aggregation level first, and if the decoding succeeds, does not need to perform decoding at a higher aggregation level. Therefore, the embodiment of the data decoding method is applicable to a process in which a decoder side performs blind detection in a search space.
A specific example is used below to further describe the data decoding method.
When encoding a group of data blocks at the aggregation level of 2, the transmit end obtains encoded c1 and c2, and sends c1 and c2 to the receive end. After receiving an LLR 1 corresponding to c1, the receive end can decode the LLR 1 to obtain u1. If a channel status becomes better, a probability of successful decoding is higher. All information bits carried in u2 and information bits carried in u1 are repeated. Therefore, if the information bits carried in u1 are obtained, all the information bits carried in u1 and u2 are obtained.
Although a PC-F bit in u1 may be used for check after c1 and c2 are received and u1 and u2 are obtained through decoding, when only the LLR 1 corresponding to c1 is received, in a process of decoding the LLR 1, based on a check relationship, a value of at least one PC-F bit in u1 is respectively equal to a value of at least one information bit I in u2, and all the information bits can be obtained by directly decoding the LLR 1.
Another specific example is used below to further describe the data decoding method.
Step 1: An eNodeB delivers, to a terminal, an encoded data block at an aggregation level of 4. The terminal first receives an LLR (Log-likelihood ratio, a log-likelihood ratio) 1 corresponding to the encoded data block c1, where the LLR 1 is obtained through processes of modulating the encoded data block c1, transmitting the encoded data block c1 through a channel, and the like, decodes the LLR 1 corresponding to the encoded data to obtain u1, and if decoding the LLR 1 succeeds, outputs an information bit carried in u1.
If decoding the LLR 1 fails, go to step 2.
Step 2: If decoding u1 fails in step 1, the terminal continues to receive an LLR 2 corresponding to data, where the LLR 2 corresponds to an encoded data block c2, and the LLR 2 is obtained through processes of modulating the encoded data block c2, transmitting the encoded data block c2 through a channel, and the like. In this way, the terminal receives both the LLR 1 and the LLR 2 corresponding to the encoded data, then decodes the LLR 1 and the LLR 2 corresponding to the encoded data, and if decoding the LLR 1 and the LLR 2 succeeds, outputs information bits carried in u1 and u2.
As shown in the figure, when the aggregation level is 2, both the LLR 2 and the LLR 1 enter the decoder, to obtain the information bits in u2 and u1. In addition, because sequential decoding is performed in the decoding process, u2 is obtained through decoding first. After u2 is obtained, an information bit I in u2 is obtained. A value of the information bit I in u2 is the same as a value of a PC-F bit in u1. The information bit I in u2 may be used to check the PC-F bit in u1. Based on the check relationship, the PC-F bit may be forcibly set to I.
If decoding c1 and c2 fails, go to step 3.
The check relationship herein relates to a step of forming a check equation in an entire PC-polar encoding process. For a PC polar code, before polar encoding is performed, check precoding is first performed on an information bit. A precoding process is briefly described as follows: The last one of members of the check equation is a check bit. A value of the check bit is addition modulo 2 of other members of the check equation. For example, if the check equation is [1 3 5 7], the subchannels 1, 3 and 5 are information subchannels. If values of the subchannels are respectively m1, m3, and m5, the value of the check bit is m7=mod(m1+m3+m5, 2). Therefore, a check function of the check frozen bit herein is to satisfy the check relationship with the foregoing information bits. For example, when the information bit m1 at the aggregation level of 1 is duplicated into the information bit m2 at the aggregation level of 2, and m1 becomes a check frozen bit, in the decoding process at the aggregation level of 2, m2 is decoded first, and it is equivalent to decoding of m1. Because m1 is used as a check bit of m2, there is a relationship: m1=m2. This relationship between m1 and m2 is used by the check equation to achieve a check function.
Step 3: If decoding the LLR 1 and the LLR 2 fails in step 2, the terminal continues to receive an LLR 3 and an LLR 4 corresponding to data. The LLR 3 corresponds to an encoded data block c3, and the LLR 3 is obtained through processes of modulating the encoded data block c3, transmitting the encoded data block c3 through a channel, and the like. The LLR 4 corresponds to an encoded data block c4, and the LLR 4 is obtained through processes of modulating the encoded data block c4, transmitting the encoded data block c4 through a channel, and the like. In this way, the terminal receives all of the LLR 1, the LLR 2, the LLR 3, and the LLR 4 corresponding to the encoded data, and decodes the LLR 1, the LLR 2, the LLR 3, and the LLR 4 corresponding to the encoded data.
As shown in the figure, when the aggregation level is 4, {LLR 4, LLR 3, LLR 2, LLR 1} sequentially enter the decoder. The LLR 4 is decoded first to obtain u4, the LLR 3 is decoded to obtain u3, the LLR 2 is then decoded to obtain u2, and the LLR 1 is decoded to obtain u1. After u4, u3, and u2 are obtained through decoding, information bits I in u4, u3, and u2 are obtained. A value of the information bit I in u4 is the same as a value of one PC-F bit in u1, a value of the information bit I in u3 is the same as a value of one PC-F bit in u1, and a value of the information bit I in u2 is the same as a value of one PC-F bit in u1. The information bits I in u4, u3, and u2 may be used to check the PC-F bits in u1. Based on the check relationship, the PC-F bit in u1 may be forcibly set to I.
If the aggregation level indicated by the eNodeB is 4, the terminal receives the LLR 3 and the LLR 4 by step 4, and if decoding the LLR 3 and the LLR 4 succeeds, may output the information bits carried in the LLR 1, the LLR 2, the LLR 3, and the LLR 4.
It may be learned from the foregoing specific example of the data decoding method that, the terminal may perform decoding at a lower aggregation level first, and if the decoding succeeds, does not need to perform decoding at a higher aggregation level, thereby reducing a decoding delay and stopping the decoding early.
As shown in
In
Therefore, when the receive end (for example, a user end or a terminal device) decodes some received LLR data at a low aggregation level, there is a possibility of successful decoding. If the decoding succeeds, a decoding delay can be significantly reduced.
The encoding module 112 is configured to encode the data block at an aggregation level of 2L, where a formula used during the encoding is as follows:
where {dot over (u)}L={uL uL−1 . . . u1}, {dot over (u)}2L={u2L u2L−1 . . . uL+1}, ċL={cL cL−1 . . . c1}, ċ2L={c2L c2L−1 . . . cL+1}, GLN=GN⊗ log
The interface module 111 is further configured to output the encoded data block.
The encoder 11 provided in this embodiment of the present invention may be configured to perform various embodiments of the data encoding method, and implementation principles and technical effects of the encoder and the data encoding method are similar. Details are not described herein again. Specifically, various specific implementations related to S101 and S103 in the data encoding method may also be correspondingly used as various specific implementations of functions of the interface module 111 in the encoder 11. Various specific implementations related to S102 in the data encoding method may also be correspondingly used as various specific implementations of functions of the encoding module 112 in Embodiment 1 of the encoder 11.
In Embodiment 2 of the encoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
In Embodiment 3 of the encoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
The decoding module 212 is configured to decode the LLR information at the aggregation level lower than 2L.
The transceiver module 211 is further configured to output a decoding result of the LLR (Log-likelihood ratio, log-likelihood ratio) information.
The decoder 21 provided in this embodiment of the present invention may be configured to perform various embodiments of the data decoding method, and implementation principles and technical effects of the decoder and the data decoding method are similar. Details are not described herein again. Specifically, various specific implementations related to S201 and S203 in the data decoding method may also be correspondingly used as various specific implementations of functions of the transceiver module 211 in Embodiment 1 of the decoder 21. Various specific implementations related to S202 in the data decoding method may also be correspondingly used as various specific implementations of functions of the decoding module 212 in Embodiment 1 of the decoder 21.
In Embodiment 2 of the decoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
In Embodiment 3 of the decoder, the memory and the processor may be located in a same circuit board, or the memory and the processor may be located in different circuit boards.
In the foregoing embodiments of the encoder and the decoder, the processor may be an integrated circuit that works according to a non-fixed instruction or an integrated circuit that works according to a fixed instruction. The processor that works according to a non-fixed instruction reads and executes the instruction in the memory to implement various embodiments of the data encoding method and the data decoding method, or implement various implementations of the functions of the interface module 111 and the encoding module 112 in Embodiment 1 of the encoder 11, or implement various implementations of the functions of the transceiver module 211 and the decoding module 212 in Embodiment 1 of the decoder 21. The processor that works according to a fixed instruction runs the hardware logical circuit of the processor to implement various embodiments of the data encoding method and the data decoding method, or implement various implementations of the functions of the interface module 111 and the encoding module 112 in Embodiment 1 of the encoder 11, or implement various implementations of the functions of the transceiver module 211 and the decoding module 212 in Embodiment 1 of the decoder 21. In a process in which the processor that works according to a fixed instruction runs the hardware logical circuit of the processor, the processor often needs to read some data from the memory, or output a running result to the memory. The memory is a storage medium that can be conveniently read by the processor, such as a random access memory (Random Access Memory, RAM for short), a flash memory, a read-only memory (Read-Only Memory, ROM for short), a programmable read-only memory, an electrically erasable programmable memory, a cache (CACHE), or a register.
In various embodiments of the foregoing encoder, decoder, and data processing apparatus, the processor may be a central processing unit (Central Processing Unit, CPU for short) and a graphics processing unit (Graphics Processing Unit, GPU for short), a digital signal processor (Digital Signal Processor, DSP for short), and an application-specific integrated circuit (Application-Specific Integrated Circuit, ASIC for short), a field programmable gate array (Field Programmable Gate Array, FPGA for short), a network processor (Network Processor, NP for short), another programmable logic device, a discrete gate transistor logic device, or a discrete hardware component, and the like.
All or some of the foregoing embodiments may be implemented by software, hardware, firmware, or any combination thereof. When software is used to implement the embodiments, the embodiments may be implemented completely or partially in a form of a computer program product. The computer program product includes one or more computer instructions. When the computer program instructions are loaded and executed on the computer, the procedure or functions according to the embodiments of the present invention are all or partially generated. The computer may be a general-purpose computer, a dedicated computer, a computer network, or other programmable apparatuses. The computer instructions may be stored in a computer-readable storage medium or may be transmitted from a computer-readable storage medium to another computer-readable storage medium. For example, the computer instructions may be transmitted from a website, computer, server, or data center to another website, computer, server, or data center in a wired (for example, a coaxial cable, an optical fiber, or a digital subscriber line (DSL)) or wireless (for example, infrared, radio, and microwave, or the like) manner. The computer-readable storage medium may be any usable medium accessible by a computer, or a data storage device, such as a server or a data center, integrating one or more usable media. The usable medium may be a magnetic medium (for example, a floppy disk, a hard disk, or a magnetic tape), an optical medium (for example, a DVD), a semiconductor medium (for example, a Solid State Disk (SSD)), or the like.
In addition, the term “and/or” in this specification describes only an association relationship for describing associated objects and represents that three relationships may exist. For example, A and/or B may represent the following three cases: Only A exists, both A and B exist, and only B exists. In addition, the character “/” in this specification generally indicates an “or” relationship between the associated objects.
Number | Date | Country | Kind |
---|---|---|---|
201710011631.7 | Jan 2017 | CN | national |
This application is a continuation of International Application No. PCT/CN2018/071616, filed on Jan. 5, 2018, which claims priority to Chinese Patent Application No. 201710011631.7, filed on Jan. 7, 2017. The disclosures of the aforementioned patent applications are hereby incorporated by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
6385671 | Hunsaker | May 2002 | B1 |
20100303011 | Pan et al. | Dec 2010 | A1 |
20130205176 | Qian et al. | Aug 2013 | A1 |
20140019820 | Vardy | Jan 2014 | A1 |
20150026543 | Li et al. | Jan 2015 | A1 |
20150077277 | Alhussien | Mar 2015 | A1 |
20150293716 | Jiang | Oct 2015 | A1 |
20160164629 | Ahn | Jun 2016 | A1 |
20160254876 | Shen | Sep 2016 | A1 |
20170005753 | Shen et al. | Jan 2017 | A1 |
Number | Date | Country |
---|---|---|
101547064 | Sep 2009 | CN |
102164025 | Aug 2011 | CN |
103368583 | Oct 2013 | CN |
105075163 | Nov 2015 | CN |
105453466 | Mar 2016 | CN |
105743621 | Jul 2016 | CN |
105874736 | Aug 2016 | CN |
3113400 | Jan 2017 | EP |
2331897 | Jun 1999 | GB |
Entry |
---|
Extended European Search Report issued in European Application No. 18735815.5 dated Nov. 27, 2019, 12 pages. |
Li et al., “Parallel Decoders of Polar Codes,” arXiv preprint arXiv:1309.1026, XP055239917, Sep. 4, 2013, pp. 1-4. |
Vangala et al., “A New Multiple Folded Successive Cancellation Decoder for Polar Codes,” 2014 IEEE Information Theory Workshop (ITW 2014), IEEE, XP032694569, Nov. 2, 2014. pp. 381-385. |
Office Action issued in Chinese Application No. 201710011631.7 dated Dec. 29, 2020, 20 pages. |
PCT International Search Report and Written Opinion in International Application No. PCT/CN2018/071,616, dated Apr. 4, 2018, 22 pages (With English Translation). |
Office Action issued in Chinese Application No. 201710011631.7 dated Oct. 9, 2021, 4 pages. |
Number | Date | Country | |
---|---|---|---|
20190334553 A1 | Oct 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2018/071616 | Jan 2018 | US |
Child | 16505200 | US |