Embodiments of the present invention relate to communications technologies, and in particular, to a data transmission method and apparatus based on unequal error protection and a device.
In addition to a feature of a large data amount, video data has a feature of generating, by means of encoding in a video encoding process, a data stream that affects, in different degrees, a receive end to perform decoding to restore the video data. Therefore, how to perform encoding according to importance of the video data to effectively protect data is a quite important issue.
In the prior art, video data is prioritized according to importance of the video data. After the video data is divided into different queues according to different priorities, the queues are sent to a convolutional encoder, and the convolutional encoder sends the queues to a comb filter. In the comb filter, according to a greedy algorithm, a high-priority data bit is placed into a location of a most significant bit (Most Significant Bit, MSB for short) of a modulation symbol, and a low-priority data bit is placed into a location of a least significant bit (Least Significant Bit, LSB for short) of the modulation symbol. In this way, data can be effectively protected.
However, a channel encoding manner used in the prior art is convolutional code, and before entering an encoder, the video data needs to be divided into different queues according to importance. Turbo encoding is used in a Long Term Evolution (Long Term Evolution, LTE for short) system. In addition, importance of the video data cannot be distinguished. Therefore, an existing video data protection manner is not applicable to the LTE system.
Embodiments of the present invention provide a data transmission method and apparatus based on unequal error protection and a device, so that unequal error protection for video data is implemented in an LTE system.
According to a first aspect, an embodiment of the present invention provides a data transmission method based on unequal error protection, including:
segmenting, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data, to obtain segmented code blocks;
performing rate matching on the segmented code blocks obtained by channel encoding, to obtain output code blocks;
cascading the output code blocks according to the quantity of symbol bits in the constellation diagram, to obtain cascaded code blocks; and
sending the cascaded code blocks to a terminal device.
With reference to the first aspect, in a first possible implementation of the first aspect, the segmenting, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data includes:
determining a segment quantity according to the quantity Qm of symbol bits in the constellation diagram, where the segment quantity is an integer multiple of Qm/2; and
segmenting the code block according to the segment quantity.
With reference to the first possible implementation of the first aspect, in a second possible implementation of the first aspect, the determining a segment quantity according to the quantity Qm of symbol bits in the constellation diagram includes:
determining the segment quantity C′ according to a formula
where Z represents a maximum value of a code block size, B represents a magnitude of an input bit stream corresponding to the code block, and L represents a magnitude of a CRC parity bit.
With reference to the first or the second possible implementation of the first aspect, in a third possible implementation of the first aspect, the cascading the output code blocks according to the quantity of symbol bits in the constellation diagram includes:
using every Qm/2 output code blocks as a code block group, and sorting the output code blocks in each code block group according to importance of the data; and
separately obtaining one bit from each sorted output code block corresponding to each code block group and cascading the obtained bits, and repeating this operation until Qm bits are cascaded.
With reference to any one of the first aspect, or the first to the third possible implementations of the first aspect, in a fourth possible implementation of the first aspect, the performing rate matching on the segmented code blocks obtained by channel encoding includes:
encoding the segmented code blocks to obtain encoded code blocks;
performing interleaving processing on the encoded code blocks by using an interleaver, to obtain interleaved code blocks; and
performing rate matching on the interleaved code blocks to obtain the output code blocks.
With reference to any one of the first aspect, or the first to the fourth possible implementations of the first aspect, in a fifth possible implementation of the first aspect, the sending the cascaded code blocks to a terminal device includes:
performing data modulation on the cascaded code blocks to obtain modulated data;
performing digital-to-analog conversion on the modulated data to obtain analog data; and
sending the analog data to the terminal device.
According to a second aspect, an embodiment of the present invention provides a data transmission method based on unequal error protection, including:
segmenting, according to a preset parameter, a code block corresponding to data, to obtain segmented code blocks;
performing encoding processing on the segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks;
performing interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram, to obtain interleaved code blocks; and
cascading the interleaved code blocks to obtain cascaded code blocks, and sending the cascaded code blocks to a terminal device.
With reference to the second aspect, in a first possible implementation of the second aspect, the segmenting, according to a preset parameter, a code block corresponding to data includes:
determining a segment quantity, a length of a segmented code block, and a quantity of first padding bits according to the preset parameter, where the padding bit is a bit used when bit padding is performed on the code block; and
performing bit padding on the code block according to the segment quantity, the length of a segmented code block, and the quantity of first padding bits, so as to segment the code block.
With reference to the first possible implementation of the second aspect, in a second possible implementation of the second aspect, the performing interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram includes:
determining a quantity of rows of an interleaver according to the quantity of symbol bits in the constellation diagram, and determining a quantity of second padding bits according to the quantity of rows of the interleaver and a preset quantity of columns of the interleaver; and
separately placing the padding bit and an information bit according to the quantity of second padding bits and the quantity of symbol bits in the constellation diagram, where the information bit is a bit corresponding to the data.
According to a third aspect, an embodiment of the present invention provides a data transmission method based on unequal error protection, including:
receiving cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram;
performing code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain split code blocks; and
performing code block cascading on the split code blocks obtained by channel decoding, to obtain the data.
With reference to the third aspect, in a first possible implementation of the third aspect, the performing code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram includes:
using every Qm/2 bits in the cascaded code blocks as a bit group, sequentially obtaining one bit from each bit group, and forming a bit stream by using the obtained bits.
With reference to the third aspect or the first possible implementation of the third aspect, in a second possible implementation of the third aspect, the performing code block cascading on the split code blocks obtained by channel decoding includes:
performing de-interleaving processing on the split code blocks by using a de-interleaver, to obtain de-interleaved code blocks;
performing decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
sequentially performing CRC check and code block cascading processing on the decoded code blocks, to obtain the data.
According to a fourth aspect, an embodiment of the present invention provides a data transmission method based on unequal error protection, including:
receiving cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a preset parameter, encoding processing is performed on the obtained segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks, interleaving processing is performed on the system bit code blocks according to a quantity of symbol bits in a constellation diagram to obtain interleaved code blocks, and the interleaved code blocks are cascaded;
performing LTE data receiving processing on the cascaded code blocks to obtain check code blocks; and
performing row-in-column-out code block cascading on the check code blocks to obtain cascaded code blocks.
With reference to the fourth aspect, in a first possible implementation of the fourth aspect, the performing LTE data receiving processing on the cascaded code block includes:
performing code block splitting on the cascaded code blocks to obtain split code blocks;
performing de-interleaving processing on the split code blocks to obtain de-interleaved code blocks;
performing decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
checking the decoded code blocks to obtain the check code blocks.
According to a fifth aspect, an embodiment of the present invention provides a data transmission apparatus based on unequal error protection, including:
a segmentation module, configured to segment, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data, to obtain segmented code blocks;
a matching module, configured to perform rate matching on the segmented code blocks obtained by channel encoding, to obtain output code blocks;
a cascading module, configured to cascade the output code blocks according to the quantity of symbol bits in the constellation diagram, to obtain cascaded code blocks; and
a sending module, configured to send the cascaded code blocks to a terminal device.
With reference to the fifth aspect, in a first possible implementation of the fifth aspect, the segmentation module includes:
a determining unit, configured to determine a segment quantity according to the quantity Qm of symbol bits in the constellation diagram, where the segment quantity is an integer multiple of Qm/2; and
a segmentation unit, configured to segment the code block according to the segment quantity.
With reference to the first possible implementation of the fifth aspect, in a second possible implementation of the fifth aspect, the determining unit is specifically configured to:
determine the segment quantity C′ according to a formula
where Z represents a maximum value of a code block size, B represents a magnitude of an input bit stream corresponding to the code block, and L represents a magnitude of a CRC parity bit.
With reference to the first or the second possible implementation of the fifth aspect, in a third possible implementation of the fifth aspect, the cascading module includes:
a sorting unit, configured to use every Qm/2 output code blocks as a code block group, and sort the output code blocks in each code block group according to importance of the data; and
an obtaining unit, configured to separately obtain one bit from each sorted output code block corresponding to each code block group and cascade the obtained bits, and repeat this operation until Qm bits are cascaded.
With reference to any one of the fifth aspect, or the first to the third possible implementations of the fifth aspect, in a fourth possible implementation of the fifth aspect, the matching module includes:
an encoding unit, configured to encode the segmented code blocks to obtain encoded code blocks;
an interleaving unit, configured to perform interleaving processing on the encoded code blocks by using an interleaver, to obtain interleaved code blocks; and
a matching unit, configured to perform rate matching on the interleaved code blocks to obtain the output code blocks.
With reference to any one of the fifth aspect, or the first to the fourth possible implementations of the fifth aspect, in a fifth possible implementation of the fifth aspect, the apparatus further includes:
a modulation module, configured to perform data modulation on the cascaded code blocks to obtain modulated data; and
a conversion module, configured to perform digital-to-analog conversion on the modulated data to obtain analog data; where
the sending module is further configured to send the analog data to the terminal device.
According to a sixth aspect, an embodiment of the present invention provides a data transmission apparatus based on unequal error protection, including:
a segmentation module, configured to segment, according to a preset parameter, a code block corresponding to data, to obtain segmented code blocks;
an encoding module, configured to perform encoding processing on the segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks;
an interleaving module, configured to perform interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram, to obtain interleaved code blocks;
a cascading module, configured to cascade the interleaved code blocks to obtain cascaded code blocks; and
a sending module, configured to send the cascaded code blocks to a terminal device.
With reference to the sixth aspect, in a first possible implementation of the sixth aspect, the segmentation module includes:
a first determining unit, configured to determine a segment quantity, a length of a segmented code block, and a quantity of first padding bits according to the preset parameter, where the padding bit is a bit used when bit padding is performed on the code block; and
a padding unit, configured to perform bit padding on the code block according to the segment quantity, the length of a segmented code block, and the quantity of first padding bits, so as to segment the code block.
With reference to the first possible implementation of the sixth aspect, in a second possible implementation of the sixth aspect, the interleaving module includes:
a second determining unit, configured to determine a quantity of rows of an interleaver according to the quantity of symbol bits in the constellation diagram, and determine a quantity of second padding bits according to the quantity of rows of the interleaver and a preset quantity of columns of the interleaver; and
a placing unit, configured to separately place the padding bit and an information bit according to the quantity of second padding bits and the quantity of symbol bits in the constellation diagram, where the information bit is a bit corresponding to the data.
According to a seventh aspect, an embodiment of the present invention provides a data transmission apparatus based on unequal error protection, including:
a receiving module, configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram;
a splitting module, configured to perform code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain split code blocks; and
a cascading module, configured to perform code block cascading on the split code blocks obtained by channel decoding, to obtain the data.
With reference to the seventh aspect, in a first possible implementation of the seventh aspect, the splitting module is specifically configured to use every Qm/2 bits in the cascaded code blocks as a bit group, sequentially obtain one bit from each bit group, and form a bit stream by using the obtained bits.
With reference to the seventh aspect or the first possible implementation of the seventh aspect, in a second possible implementation of the seventh aspect, the cascading module includes:
a de-interleaving unit, configured to perform de-interleaving processing on the split code blocks by using a de-interleaver, to obtain de-interleaved code blocks;
a decoding unit, configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
a processing unit, configured to sequentially perform CRC check and code block cascading processing on the decoded code blocks, to obtain the data.
According to an eighth aspect, an embodiment of the present invention provides a data transmission apparatus based on unequal error protection, including:
a receiving module, configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a preset parameter, encoding processing is performed on the obtained segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks, interleaving processing is performed on the system bit code blocks according to a quantity of symbol bits in a constellation diagram to obtain interleaved code blocks, and the interleaved code blocks are cascaded;
a processing module, configured to perform LTE data receiving processing on the cascaded code blocks to obtain check code blocks; and
a cascading module, configured to perform row-in-column-out code block cascading on the check code blocks to obtain cascaded code blocks.
With reference to the eighth aspect, in a first possible implementation of the eighth aspect, the processing module includes:
a splitting unit, configured to perform code block splitting on the cascaded code blocks to obtain split code blocks;
a de-interleaving unit, configured to perform de-interleaving processing on the split code blocks to obtain de-interleaved code blocks;
a decoding unit, configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
a check unit, configured to check the decoded code blocks to obtain the check code blocks.
According to a ninth aspect, an embodiment of the present invention provides a base station, including:
a processor, configured to segment, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data, to obtain segmented code blocks, where
the processor is further configured to perform rate matching on the segmented code blocks obtained by channel encoding, to obtain output code blocks; and
the processor is further configured to cascade the output code blocks according to the quantity of symbol bits in the constellation diagram, to obtain cascaded code blocks; and
a transmitter, configured to send the cascaded code blocks to a terminal device.
With reference to the ninth aspect, in a first possible implementation of the ninth aspect, the processor is further configured to determine a segment quantity according to the quantity Qm of symbol bits in the constellation diagram, where the segment quantity is an integer multiple of Qm/2; and
the processor is further configured to segment the code block according to the segment quantity.
With reference to the first possible implementation of the ninth aspect, in a second possible implementation of the ninth aspect, the processor is further configured to determine the segment quantity C′ according to a formula
where Z represents a maximum value of a code block size, B represents a magnitude of an input bit stream corresponding to the code block, and L represents a magnitude of a CRC parity bit.
With reference to the first or the second possible implementation of the ninth aspect, in a third possible implementation of the ninth aspect, the processor is further configured to use every Qm/2 output code blocks as a code block group, and sort the output code blocks in each code block group according to importance of the data; and
the processor is further configured to separately obtain one bit from each sorted output code block corresponding to each code block group and cascade the obtained bits, and repeat this operation until Qm bits are cascaded.
With reference to any one of the ninth aspect, or the first to the third possible implementations of the ninth aspect, in a fourth possible implementation of the ninth aspect, the processor is further configured to encode the segmented code blocks to obtain encoded code blocks;
the processor is further configured to perform interleaving processing on the encoded code blocks by using an interleaver, to obtain interleaved code blocks; and
the processor is further configured to perform rate matching on the interleaved code blocks to obtain the output code blocks.
With reference to any one of the ninth aspect, or the first to the fourth possible implementations of the ninth aspect, in a fifth possible implementation of the ninth aspect, the processor is further configured to perform data modulation on the cascaded code blocks to obtain modulated data;
the processor is further configured to perform digital-to-analog conversion on the modulated data to obtain analog data; and
the transmitter is further configured to send the analog data to the terminal device.
According to a tenth aspect, an embodiment of the present invention provides a base station, including:
a processor, configured to segment, according to a preset parameter, a code block corresponding to data, to obtain segmented code blocks, where
the processor is further configured to perform encoding processing on the segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks;
the processor is further configured to perform interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram, to obtain interleaved code blocks; and
the processor is further configured to cascade the interleaved code blocks to obtain cascaded code blocks; and
a transmitter, configured to send the cascaded code blocks to a terminal device.
With reference to the tenth aspect, in a first possible implementation of the tenth aspect, the processor is further configured to determine a segment quantity, a length of a segmented code block, and a quantity of first padding bits according to the preset parameter, where the padding bit is a bit used when bit padding is performed on the code block; and
the processor is further configured to perform bit padding on the code block according to the segment quantity, the length of a segmented code block, and the quantity of first padding bits, so as to segment the code block.
With reference to the first possible implementation of the tenth aspect, in a second possible implementation of the tenth aspect, the processor is further configured to determine a quantity of rows of an interleaver according to the quantity of symbol bits in the constellation diagram, and determine a quantity of second padding bits according to the quantity of rows of the interleaver and a preset quantity of columns of the interleaver; and
the processor is further configured to separately place the padding bit and an information bit according to the quantity of second padding bits and the quantity of symbol bits in the constellation diagram, where the information bit is a bit corresponding to the data.
According to an eleventh aspect, an embodiment of the present invention provides a terminal device, including:
a receiver, configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram; and
a processor, configured to perform code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain split code blocks, where
the processor is further configured to perform code block cascading on the split code blocks obtained by channel decoding, to obtain the data.
With reference to the eleventh aspect, in a first possible implementation of the eleventh aspect, the processor is further configured to use every Qm/2 bits in the cascaded code blocks as a bit group, sequentially obtain one bit from each bit group, and form a bit stream by using the obtained bits.
With reference to the eleventh aspect or the first possible implementation of the eleventh aspect, in a second possible implementation of the eleventh aspect, the processor is further configured to perform de-interleaving processing on the split code blocks by using a de-interleaver, to obtain de-interleaved code blocks;
the processor is further configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
the processor is further configured to sequentially perform CRC check and code block cascading processing on the decoded code blocks, to obtain the data.
According to a twelfth aspect, an embodiment of the present invention provides a terminal device, including:
a receiver, configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a preset parameter, encoding processing is performed on the obtained segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks, interleaving processing is performed on the system bit code blocks according to a quantity of symbol bits in a constellation diagram to obtain interleaved code blocks, and the interleaved code blocks are cascaded; and
a processor, configured to perform LTE data receiving processing on the cascaded code blocks to obtain check code blocks, where
the processor is further configured to perform row-in-column-out code block cascading on the check code blocks to obtain cascaded code blocks.
With reference to the twelfth aspect, in a first possible implementation of the twelfth aspect, the processor is further configured to perform code block splitting on the cascaded code blocks to obtain split code blocks;
the processor is further configured to perform de-interleaving processing on the split code blocks to obtain de-interleaved code blocks;
the processor is further configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
the processor is further configured to check the decoded code blocks to obtain the check code blocks.
According to the data transmission method and apparatus based on unequal error protection and the device provided in the embodiments of the present invention, the code block corresponding to the data is segmented according to the quantity of symbol bits in the constellation diagram to obtain the segmented code blocks, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain the output code blocks, the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. The base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system.
To describe the technical solutions in the embodiments of the present invention more clearly, the following briefly describes the accompanying drawings required for describing the embodiments. Apparently, the accompanying drawings in the following description show merely some embodiments of the present invention, and a person of ordinary skill in the art may still derive other drawings from these accompanying drawings without creative efforts.
The following clearly describes the technical solutions in the embodiments of the present invention with reference to the accompanying drawings in the embodiments of the present invention. Apparently, the described embodiments are merely some but not all of the embodiments of the present invention. All other embodiments obtained by a person of ordinary skill in the art based on the embodiments of the present invention without creative efforts shall fall within the protection scope of the present invention.
Detailed descriptions are provided below with reference to several embodiments.
On the basis of the foregoing system architecture shown in
Step 201: Segment, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data, to obtain segmented code blocks.
In this embodiment, when the base station receives a message that is sent by a terminal device and that is used to request to receive video data, the base station packs SVC video source data in a unit of byte, that is, performs related processing in a format of a Media Access Control (Media Access Control, MAC for short) protocol data unit (Protocol Data Unit, PDU for short). In a specific implementation process, an L-bit parity bit is first added to a tail of the MAC PDU, to verify whether the MAC PDU is correct. For example, a CRC check manner may be used. A 24-bit parity bit is added to the tail of the MAC PDU. After the parity bit is added, if a length of the MAC PDU is greater than a maximum value 6144 of a code block size, a segment quantity needs to be determined according to the quantity of symbol bits in the constellation diagram, the code block corresponding to the data is segmented according to the segment quantity, and cyclic redundancy check (Cyclic Redundancy Check, CRC for short) redundancy is added to each segmented code block.
Step 202: Perform rate matching on the segmented code blocks obtained by channel encoding, to obtain output code blocks.
In this embodiment, the base station segments the code block, and encodes the segmented code blocks after obtaining the segmented code blocks. In an LTE system, a Turbo encoding manner is usually used. After encoding is performed, system bit code blocks in one channel and parity bit code blocks in two channels are obtained, and interleaving and bit collection processing are separately performed on the code blocks in three channels by using a sub-interleaver, so as to combine the code blocks in three channels into code blocks in one channel. Then, rate matching is performed on the code blocks in one channel to obtain the output code blocks.
Step 203: Cascade the output code blocks according to the quantity of symbol bits in the constellation diagram, to obtain cascaded code blocks.
In this embodiment, the obtained output code blocks are concatenated according to the quantity of symbol bits in the constellation diagram, so that the code blocks are cascaded to obtain the cascaded code blocks.
Step 204: Send the cascaded code blocks to a terminal device.
In this embodiment, the base station sends the cascaded code blocks to the terminal device, so that the terminal device performs code block splitting and decoding processing on the cascaded code blocks to obtain a MAC PDU data packet.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the code block corresponding to the data is segmented according to the quantity of symbol bits in the constellation diagram to obtain the segmented code blocks, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain the output code blocks, the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. The base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in the LTE system.
On the basis of the foregoing system architecture shown in
Step 301: Determine a segment quantity according to the quantity Qm of symbol bits in the constellation diagram, where the segment quantity is an integer multiple of Qm/2.
In this embodiment, the segment quantity C is determined according to a formula
Z represents a maximum value of a code block size and is generally 6144. B represents a magnitude of an input bit stream corresponding to the code block. L represents a magnitude of a CRC parity bit. ┌●┐ represents rounding up; for example, if a calculated value is 3.5, a result of rounding up is 4. The segment quantity C determined according to the foregoing formula is an integer multiple of Qm/2. The quantity Qm of symbol bits in the constellation diagram is determined according to a modulation manner selected by an MCS. For example, during 16 quadrature amplitude modulation (Quadrature Amplitude Modulation, QAM for short), Qm is 4; during 64QAM, Qm is 6; and during 256QAM, Qm is 8.
Step 302: Segment the code block according to the segment quantity.
In this embodiment, after the segment quantity is determined, the code block corresponding to the data is segmented according to the segment quantity. By using a manner for determining the segment quantity according to the quantity Qm of symbol bits in the constellation diagram and segmenting the code block according to the segment quantity, it may be ensured that important data in the code block is mapped to a location of an MSB in the constellation diagram, and unimportant data is mapped to a location of an LSB in the constellation diagram, so that unequal error protection can be performed according to importance of the data.
It should be noted that when a quantity of code blocks is greater than 3, the code blocks need to be rearranged. In a specific implementation process, if there are n*Qm/2 blocks, the first n*Qm/6 blocks are separately arranged at (1+k*Qm/2) the middle n*Qm/6 blocks are separately arranged at (2+k*Qm/2), and the last n*Qm/6 blocks are separately arranged at (3+k*Qm/2), where n and k are both integers greater than or equal to zero.
Step 303: Encode the segmented code blocks to obtain encoded code blocks.
In this embodiment, Turbo encoding is performed on the segmented code blocks. Turbo mainly includes parallel cascading convolutional codes, two 8-state sub-encoders, and one Turbo inner-code interleaver. Therefore, a result of Turbo encoding is divided into three channels: The first channel includes system bits, and the last two channels include parity bits. When encoding starts, an initial value of a shift register of the 8-state sub-encoder is 0.
A primary function of the Turbo inner-code interleaver is to combine two mutually independent short codes into one long random code based on an idea of randomization, because performance of a long code can approach the Shannon limit. In addition, the interleaver may be configured to disperse a burst error, and the interleaver may be further configured to break a low-weight input sequence mode, so as to increase a minimum Hamming distance of an output code word or decrease a quantity of low-weight output code words.
Step 304: Perform interleaving processing on the encoded code blocks by using an interleaver, to obtain interleaved code blocks.
In this embodiment, it is assumed that a bit stream that is input into the interleaver is d0(i), d1(i), d2(i), . . . , dD−1(i), where D is a quantity of input bits. A quantity of columns of a matrix in the interleaver is CsubblockTC=32, and numbers from left to right are successively 0, 1, 2, . . . , CsubblockTC−1. In addition, to avoid a mistake and improve interleaving correctness, a size of the matrix is required to be greater than or equal to D, that is, D≤(RsubblockTC×CsubblockTC), where RsubblockTC is a quantity of rows of the matrix. Therefore, a value of RsubblockTC is a minimum integer value of D≤(RsubblockTC×CsubblockTC), and numbers of the rows of the matrix from top to bottom are successively 0, 1, 2, . . . , RsubblockTC−1.
Because D≤(RsubblockTC×CsubblockTC), the matrix needs to include some padding bits, so as to perform bit padding. Therefore, the matrix includes an information bit and a padding bit. The information bit is a bit corresponding to the data. If (RsubblockTC×CsubblockTC)>D, ND=(RsubblockTC×CsubblockTC−D) dummy bits need to be added to the matrix.
In this embodiment, entering the interleaver in a row-in manner is described. A column-in manner is similar to this, and details are not described herein again. After a quantity of padding bits is determined, a bit sequence yN
Because the result obtained after encoding processing includes data in three channels, correspondingly, three interleavers are required to separately perform interleaving processing on the data in three channels. After the interleaver is entered in the foregoing matrix manner, the three interleavers separately perform corresponding processing on the input matrix.
Specifically, for the system bits in the first channel, an interleaving manner is column permutation. Table 1 shows a column permutation form.
As shown in Table 1, P(j) and a number in the second row and the second column in Table 1 are in a one-to-one correspondence. For example, an original first column is permutated into a sixteenth column, and an original second column is permutated into an eighth column. A transformed matrix is:
P(j) represents an original column location of jth transformed column. For example, yP(1) in a permutated matrix is corresponding to a bit of y16 in the original matrix.
For the parity bits in the second channel, an interleaving manner is a row-in-column-out manner, that is, a bit sequence is read column by column.
For the parity bits in the second channel, output bits may be expressed as v0(2), v1(2), v2(2), . . . , vK
Step 305: Perform rate matching on the interleaved code blocks to obtain the output code blocks.
In this embodiment, rate matching is performed in a unit of code block. In this case, it is assumed that an input sequence is wr0 wr1 . . . wr(3Tr−1). A buffer size NIR of a single process and a single stream is first calculated according to the following formula:
└●┘ represents rounding down; Nsoft is maximum data cache that can be processed by UE; KMIMO is determined by a quantity of streams and a value is 1 or 2; MDL_HARQ is a maximum quantity of downlink hybrid automatic repeat request (Hybrid Automatic Repeat reQuest, HARQ for short) processes; Mlimit represents a constant whose value is 8; min(MDL_HARQ,Mlimit) is a quantity of HARQ processes.
Then, a buffer size Ncb of each code block is calculated according to a formula (4):
C is a quantity of code blocks, and Kw is a total magnitude of a bit stream from three sub-interleavers.
After the buffer size of each code block is calculated, an output length Er of each code block after rate matching is performed is calculated according to a formula (5):
γ=G′ mod C, G′=G/(NL·Qm), r is an integer from 0 to C−1, and G is a total quantity of bits that can be transmitted according to an allocated available RB resource.
It should be noted that because a padding bit is padded into the matrix during interleaving processing, when rate matching is performed, if a padding bit is detected, the padding bit is directly skipped, and a next bit is matched. In this way, rate matching is not performed on the padding bit, and bandwidth is effectively saved.
Step 306: Use every Qm/2 output code blocks as a code block group, and sort the output code blocks in each code block group according to importance of the data.
In this embodiment, to ensure that a bit is mapped to a corresponding location of each constellation symbol according to importance of the data, every Qm/2 output code blocks are used as a code block group, and data with progressively decreasing importance is separately placed into one code block group.
Step 307: Separately obtain one bit from each sorted output code block corresponding to each code block group and cascade the obtained bits, and repeat this operation until Qm bits are cascaded.
In this embodiment, when the code blocks are cascaded, a code block group is used as a unit; and for each code block group, the sorted output code blocks are scanned, and one bit is obtained from each output code block. In this way, each time bit selection is performed, Qm/2 code blocks can be obtained. Because every Qm bits are corresponding to a symbol in the constellation diagram, selection needs to be consecutively performed twice to obtain Qm bits. After selection is performed on a code block group, selection is performed on a following code block group. After the bits in each code block are obtained in this manner, when constellation mapping is performed, different data is mapped to a corresponding location according to importance of the data.
64QAM is used as an example for description.
Step 308: Perform data modulation on the cascaded code blocks to obtain modulated data.
Step 309: Perform digital-to-analog conversion on the modulated data to obtain analog data.
Step 310: Send the analog data to the terminal device.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the code block corresponding to the data is segmented according to the quantity of symbol bits in the constellation diagram to obtain the segmented code blocks, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain the output code blocks, the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. The base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in the LTE system. In addition, importance of video data is distinguished according to a code block, so that operability is improved.
On the basis of the foregoing system architecture shown in
Step 701: Receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram.
In this embodiment, when the base station receives a message that is sent by the terminal device and that is used to request to receive data, the base station packs SVC video source data in a unit of byte, that is, performs related processing in a format of a Media Access Control (Media Access Control, MAC for short) protocol data unit (Protocol Data Unit, PDU for short). In a specific implementation process, an L-bit parity bit is first added to a tail of the MAC PDU, to verify whether the MAC PDU is correct. For example, a CRC check manner may be used. A 24-bit parity bit is added to the tail of the MAC PDU. After the parity bit is added, if a length of the MAC PDU is greater than a maximum value 6144 of the code block, a segment quantity needs to be determined according to the quantity of symbol bits in the constellation diagram, the code block corresponding to the data is segmented according to the segment quantity, and cyclic redundancy check (Cyclic Redundancy Check, CRC for short) redundancy is added to each segmented code block.
The base station segments the code block, and encodes the segmented code blocks after obtaining the segmented code blocks. In an LTE system, a Turbo encoding manner is usually used. After encoding is performed, system bit code blocks in one channel and parity bit code blocks in two channels are obtained, and interleaving and bit collection processing are separately performed on the code blocks in three channels by using a sub-interleaver, so as to combine the code blocks in three channels into code blocks in one channel. Then, rate matching is performed on the code blocks in one channel to obtain the output code blocks. The base station concatenates the obtained output code blocks according to the quantity of symbol bits in the constellation diagram, so as to cascade the code blocks to obtain the cascaded code blocks, and sends the cascaded code blocks to the terminal device.
Step 702: Perform code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain split code blocks.
In this embodiment, the base station performs code block cascading according to the quantity of symbol bits in the constellation diagram. Correspondingly, after receiving the cascaded code blocks sent by the base station, the terminal device needs to perform code block splitting according to the quantity of symbol bits in the constellation diagram, to obtain the split code block.
Step 703: Perform code block cascading on the split code blocks obtained by channel decoding, to obtain the data.
In this embodiment, when cascading the decoded split code blocks, the terminal device sequentially concatenates all code blocks, to obtain an output sequence bit, that is, obtain a MAC PDU data packet.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the base station segments, according to the quantity of symbol bits in the constellation diagram, the code block corresponding to the data to obtain the segmented code blocks, performs rate matching on the segmented code blocks obtained by channel encoding to obtain the output code blocks, cascades the output code blocks according to the quantity of symbol bits in the constellation diagram to obtain the cascaded code blocks, and sends the cascaded code blocks to the terminal device. The base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in the LTE system. In addition, the terminal device performs code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain data whose arrangement sequence is the same as that of original data, so that unequal error protection for video data is implemented.
On the basis of the foregoing system architecture shown in
Step 801: Receive the cascaded code blocks sent by the base station, where the cascaded code blocks are obtained after the code block corresponding to the data is segmented according to the quantity of symbol bits in the constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain the output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram.
Step 802: Use every Qm/2 bits in the cascaded code blocks as a bit group, sequentially obtain one bit from each bit group, and form a bit stream by using the obtained bits.
In this embodiment, step 802 is an inverse operation of step 306 and step 307. Specifically, received 64QAM symbols are arranged vertically. A second symbol is connected to a previous symbol after being arranged vertically, the rest are arranged sequentially, and finally code blocks are formed by row for outputting. In this way, code block splitting is completed, and data that is on the base station side and that is mapped to a corresponding location in the constellation diagram according to data importance is restored.
Step 803: Perform de-interleaving processing on the split code blocks by using a de-interleaver, to obtain de-interleaved code blocks.
Step 803 is an inverse operation of step 304.
Step 804: Perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks.
Step 804 is an inverse operation of step 303.
Step 805: Sequentially perform CRC check and code block cascading processing on the decoded code blocks, to obtain the data.
In this embodiment, when the code blocks after CRC check are cascaded, the code blocks are sequentially concatenated, to obtain the MAC PDU data packet.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in the LTE system. In addition, the terminal device performs, according to the quantity of symbol bits in the constellation diagram, code block splitting on the cascaded code blocks sent by the base station, and performs code block cascading on the obtained split code block. Code blocks mapped to different locations can be split, data is obtained, and scalability of a communications system is improved.
On the basis of the foregoing system architecture shown in
Step 901: Segment, according to a preset parameter, a code block corresponding to data, to obtain segmented code blocks.
In this embodiment, in 16QAM, a value of Qm/2 is 2; or in 256QAM, a value of Qm/2 is 4. Because a bit stream length Dr that is input into a sub-interleaver is required to be an integer multiple of 2 or 4, when the code block is output from a Turbo encoder, four tail bits need to be added to bits in each channel. That is, Dr=Kr+4, where Kr represents a length of an rth code block when the code block is input into the Turbo encoder, and Dr represents a length of the rth code block when the code block is output from the Turbo encoder. According to an existing protocol, a length of a Turbo code block meets this condition; therefore, a parameter calculation method for code block segmentation is the same as that in the prior art.
However, in 64QAM, to ensure that a sequence of mapping to MSBs, MIDs, and LSBs on a constellation symbol is not affected after the sub-interleaver performs column permutation on the code block, a code block length is required to meet a condition that (Kr+4)mod 3=0. Therefore, a segment quantity needs to be determined according to the preset parameter, and the code block corresponding to the data is segmented.
Step 902: Perform encoding processing on the segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks.
Step 902 is similar to step 303, and details are not described herein again.
Step 903: Perform interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram, to obtain interleaved code blocks.
In this embodiment, after encoding processing is performed on the segmented code blocks, system bit code blocks and parity bit code blocks in two channels are obtained. For an interleaving processing manner corresponding to the parity bit code blocks in two channels, refer to step 304, and details are not described herein again.
The system bit code blocks may be processed according to the quantity of symbol bits in the constellation diagram, to obtain the interleaved code blocks.
Step 904: Cascade the interleaved code blocks to obtain cascaded code blocks, and send the cascaded code blocks to a terminal device.
In this embodiment, the obtained interleaved code blocks are sequentially concatenated to obtain the cascaded code blocks; data modulation and digital-to-analog conversion are sequentially performed on the cascaded code blocks to obtain analog data; and the analog data is sent to the terminal device, so that the terminal device performs decoding to obtain the data.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the code block corresponding to video data is segmented according to the preset parameter to obtain the segmented code blocks; encoding processing is performed on the segmented code blocks to obtain the encoded code blocks, where the encoded code blocks include the system bit code blocks; interleaving processing is performed on the system bit code blocks according to the quantity of symbol bits in the constellation diagram to obtain the interleaved code blocks; and the interleaved code blocks are cascaded to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. The base station performs interleaving processing on the system bit code blocks according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system.
On the basis of the foregoing system architecture shown in
Step 1001: Determine a segment quantity, a length of a segmented code block, and a quantity of first padding bits according to the preset parameter, where the padding bit is a bit used when bit padding is performed on the code block.
In this embodiment, in 64QAM, the code block length is required to meet the condition that (Kr+4)mod 3=0. Therefore, a Kr value that meets this condition in Table 2 needs to be selected to form a new 64QAM code block length table. Table 2 shows an original code block segment length and some Turbo inner-code interleaver parameters, and Table 3 shows a modified code block segment length and some Turbo inner-code interleaver parameters.
When a total quantity of code blocks and a code block length are calculated, C+, C−, K+, K−, and F are determined according to an existing method and based on Table 3. K+ and K− represent the code block length; C+ represents a quantity of code blocks whose code block lengths are K+; C− represents a quantity of code blocks whose code block lengths are K−; and F is a quantity of padding bits.
Step 1002: Perform bit padding on the code block according to the segment quantity, the length of a segmented code block, and the quantity of first padding bits.
In this embodiment,
Step 1003: Perform encoding processing on the segmented code blocks to obtain the encoded code blocks, where the encoded code blocks include the system bit code blocks.
Step 1004: Determine a quantity of rows of an interleaver according to the quantity of symbol bits in the constellation diagram, and determine a quantity of second padding bits according to the quantity of rows of the interleaver and a preset quantity of columns of the interleaver.
In this embodiment, a quantity of rows of the sub-interleaver is required to be a minimum integer value of RsubblockTC*32>D and
where RsubblockTC is the quantity of rows of the sub-interleaver, and D is a quantity of input bits. In addition, the quantity of second padding bits ND=RsubblockTC*CsubblockTC−D, where CsubblockTC is a quantity of columns of the interleaver, and a value is generally 32.
Step 1005: Separately place the padding bit and an information bit according to the quantity of second padding bits and the quantity of symbol bits in the constellation diagram, where the information bit is a bit corresponding to the data.
Step 1006: Cascade the interleaved code blocks to obtain the cascaded code blocks, and send the cascaded code blocks to the terminal device.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the code block corresponding to the data is segmented according to the preset parameter to obtain the segmented code blocks; encoding processing is performed on the segmented code blocks to obtain the encoded code blocks, where the encoded code blocks include the system bit code blocks; interleaving processing is performed on the system bit code blocks according to the quantity of symbol bits in the constellation diagram to obtain the interleaved code blocks; and the interleaved code blocks are cascaded to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. The base station performs interleaving processing on the system bit code blocks according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in the LTE system. In addition, importance of the data is distinguished according to a code block, any modulation manner may be adapted to, and system scalability is improved.
On the basis of the foregoing system architecture shown in
Step 1301: Receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram.
In this embodiment, to ensure, by the base station, that a sequence of mapping to MSBs, MIDs, and LSBs on a constellation symbol is not affected after a sub-interleaver performs column permutation on the code block, a code block length is required to meet a condition that (Kr+4)mod 3=0. Therefore, a segment quantity needs to be determined according to a preset parameter, and the code block corresponding to the data is segmented. After segmenting is completed, the obtained segmented code block is encoded to obtain an encoded code block, where the encoded code blocks include system bit code blocks. Then, interleaving processing is performed on the system bit code blocks according to the quantity of symbol bits in the constellation diagram to obtain interleaved code blocks, the interleaved code blocks are cascaded to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device.
Step 1302: Perform LTE data receiving processing on the cascaded code blocks to obtain check code blocks.
In this embodiment, after the cascaded code blocks sent by the base station are received, code block splitting is performed on the cascaded code block, and de-interleaving processing, decoding processing, and CRC check are sequentially performed on an obtained split code block to obtain the check code blocks.
Step 1303: Perform column-in-row-out code block cascading on the check code blocks to obtain cascaded code blocks.
In this embodiment, the check code blocks are cascaded according to a column-in-row-out principle to form data in a BL+EL form, so that a sequence of cascaded data is consistent with that of original MAC PDU data.
According to the data transmission method based on unequal error protection provided in this embodiment of the present invention, the cascaded code blocks sent by the base station are received, LTE data receiving processing is performed on the cascaded code blocks to obtain the check code blocks, and row-in-column-out code block cascading is performed on the check code blocks to obtain the cascaded code blocks. The base station performs interleaving processing on the system bit code blocks according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system. In addition, the terminal device performs column-in-row-out code block cascading on the check code block, so that the sequence of the cascaded data is consistent with that of the original MAC PDU data, unequal error protection for video data is implemented, and video quality is improved.
The segmentation module 11 is configured to segment, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data, to obtain segmented code blocks. The matching module 12 is configured to perform rate matching on the segmented code blocks obtained by channel encoding, to obtain output code blocks. The cascading module 13 is configured to cascade the output code blocks according to the quantity of symbol bits in the constellation diagram, to obtain cascaded code blocks. The sending module 14 is configured to send the cascaded code blocks to a terminal device.
According to the data transmission apparatus based on unequal error protection provided in this embodiment of the present invention, the code block corresponding to the data is segmented according to the quantity of symbol bits in the constellation diagram to obtain the segmented code blocks, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain the output code blocks, the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. A base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system.
a determining unit 111, configured to determine a segment quantity according to the quantity Qm of symbol bits in the constellation diagram, where the segment quantity is an integer multiple of Qm/2; and
a segmentation unit 112, configured to segment the code block according to the segment quantity.
Optionally, the determining unit 111 is specifically configured to:
determine the segment quantity C′ according to a formula
where Z represents a maximum value of a code block size, B represents a magnitude of an input bit stream corresponding to the code block, and L represents a magnitude of a CRC parity bit.
The data transmission apparatus based on unequal error protection in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the data transmission apparatus are similar to those of the data transmission method, and details are not described herein again.
a sorting unit 131, configured to use every Qm/2 output code blocks as a code block group, and sort the output code blocks in each code block group according to importance of the data; and
an obtaining unit 132, configured to separately obtain one bit from each sorted output code block corresponding to each code block group and cascade the obtained bits, and repeat this operation until Qm bits are cascaded.
The data transmission apparatus based on unequal error protection in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the data transmission apparatus are similar to those of the data transmission method, and details are not described herein again.
an encoding unit 121, configured to encode the segmented code blocks to obtain encoded code blocks;
an interleaving unit 122, configured to perform interleaving processing on the encoded code blocks by using an interleaver, to obtain interleaved code blocks;
and a matching unit 123, configured to perform rate matching on the interleaved code blocks to obtain the output code blocks.
Optionally, the apparatus further includes:
a modulation module 15, configured to perform data modulation on the cascaded code blocks to obtain modulated data; and
a conversion module 16, configured to perform digital-to-analog conversion on the modulated data to obtain analog data; where
the sending module 14 is further configured to send the analog data to the terminal device.
The data transmission apparatus based on unequal error protection in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the data transmission apparatus are similar to those of the data transmission method, and details are not described herein again.
The segmentation module 21 is configured to segment, according to a preset parameter, a code block corresponding to data, to obtain segmented code blocks.
The encoding module 22 is configured to perform encoding processing on the segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks.
The interleaving module 23 is configured to perform interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram, to obtain interleaved code blocks.
The cascading module 24 is configured to cascade the interleaved code blocks to obtain cascaded code blocks.
The sending module 25 is configured to send the cascaded code blocks to a terminal device.
According to the data transmission apparatus based on unequal error protection provided in this embodiment of the present invention, the code block corresponding to the data is segmented according to the preset parameter to obtain the segmented code blocks; encoding processing is performed on the segmented code blocks to obtain the encoded code blocks, where the encoded code blocks include the system bit code blocks; interleaving processing is performed on the system bit code blocks according to the quantity of symbol bits in the constellation diagram to obtain the interleaved code blocks; and the interleaved code blocks are cascaded to obtain the cascaded code blocks, and the cascaded code blocks are sent to the terminal device. A base station performs interleaving processing on the system bit code blocks according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system.
a first determining unit 211, configured to determine a segment quantity, a length of a segmented code block, and a quantity of first padding bits according to the preset parameter, where the padding bit is a bit used when bit padding is performed on the code block; and
a padding unit 212, configured to perform bit padding on the code block according to the segment quantity, the length of a segmented code block, and the quantity of first padding bits, so as to segment the code block.
Optionally, the interleaving module 23 includes:
a second determining unit 231, configured to determine a quantity of rows of an interleaver according to the quantity of symbol bits in the constellation diagram, and determine a quantity of second padding bits according to the quantity of rows of the interleaver and a preset quantity of columns of the interleaver; and
a placing unit 232, configured to separately place the padding bit and an information bit according to the quantity of second padding bits and the quantity of symbol bits in the constellation diagram, where the information bit is a bit corresponding to the data.
The data transmission apparatus based on unequal error protection in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the data transmission apparatus are similar to those of the data transmission method, and details are not described herein again.
The receiving module 31 is configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram. The splitting module 32 is configured to perform code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain split code blocks. The cascading module 33 is configured to perform code block cascading on the split code blocks obtained by channel decoding, to obtain the data.
According to the data transmission apparatus based on unequal error protection provided in this embodiment of the present invention, the base station segments, according to the quantity of symbol bits in the constellation diagram, the code block corresponding to the data to obtain the segmented code blocks, performs rate matching on the segmented code blocks obtained by channel encoding to obtain the output code blocks, cascades the output code blocks according to the quantity of symbol bits in the constellation diagram to obtain the cascaded code blocks, and sends the cascaded code blocks to the terminal device. The base station performs segmentation and cascading processing on the code block according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system. In addition, the terminal device performs code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain data whose arrangement sequence is the same as that of original data, so that unequal error protection for data is implemented.
Optionally, the splitting module 32 is specifically configured to use every Qm/2 bits in the cascaded code blocks as a bit group, sequentially obtain one bit from each bit group, and form a bit stream by using the obtained bits.
a de-interleaving unit 331, configured to perform de-interleaving processing on the split code blocks by using a de-interleaver, to obtain de-interleaved code blocks;
a decoding unit 332, configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
a processing unit 333, configured to sequentially perform CRC check and code block cascading processing on the decoded code blocks, to obtain the data.
The data transmission apparatus based on unequal error protection in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the data transmission apparatus are similar to those of the data transmission method, and details are not described herein again.
The receiving module 41 is configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a preset parameter, encoding processing is performed on the obtained segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks, interleaving processing is performed on the system bit code blocks according to a quantity of symbol bits in a constellation diagram to obtain interleaved code blocks, and the interleaved code blocks are cascaded. The processing module 42 is configured to perform LTE data receiving processing on the cascaded code blocks to obtain check code blocks. The cascading module 43 is configured to perform row-in-column-out code block cascading on the check code blocks to obtain cascaded code blocks.
According to the data transmission apparatus based on unequal error protection provided in this embodiment of the present invention, the cascaded code blocks sent by the base station are received, LTE data receiving processing is performed on the cascaded code blocks to obtain the check code blocks, and row-in-column-out code block cascading is performed on the check code blocks to obtain the cascaded code blocks. The base station performs interleaving processing on the system bit code blocks according to the quantity of symbol bits in the constellation diagram, so that important data in the data is mapped to a location with a lower bit error rate in the constellation diagram. In this way, a purpose of unequal error protection for data can also be achieved in an LTE system.
a splitting unit 421, configured to perform code block splitting on the cascaded code blocks to obtain split code blocks;
a de-interleaving unit 422, configured to perform de-interleaving processing on the split code blocks to obtain de-interleaved code blocks;
a decoding unit 423, configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks; and
a check unit 424, configured to check the decoded code blocks to obtain the check code blocks.
The data transmission apparatus based on unequal error protection in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the data transmission apparatus are similar to those of the data transmission method, and details are not described herein again.
The processor 51 is configured to segment, according to a quantity of symbol bits in a constellation diagram, a code block corresponding to data, to obtain segmented code blocks.
The processor 51 is further configured to perform rate matching on the segmented code blocks obtained by channel encoding, to obtain output code blocks.
The processor 51 is further configured to cascade the output code blocks according to the quantity of symbol bits in the constellation diagram, to obtain cascaded code blocks.
The transmitter 52 is configured to send the cascaded code blocks to a terminal device.
The base station provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the base station are similar to those of the data transmission method, and details are not described herein again.
Optionally, the processor 51 is further configured to determine a segment quantity according to the quantity Qm of symbol bits in the constellation diagram, where the segment quantity is an integer multiple of Qm/2.
The processor 51 is further configured to segment the code block according to the segment quantity.
Optionally, the processor 51 is further configured to determine the segment quantity C′ according to a formula
where Z represents a maximum value of a code block size, B represents a magnitude of an input bit stream corresponding to the code block, and L represents a magnitude of a CRC parity bit.
Optionally, the processor 51 is further configured to use every Qm/2 output code blocks as a code block group, and sort the output code blocks in each code block group according to importance of the data.
The processor 51 is further configured to separately obtain one bit from each sorted output code block corresponding to each code block group and cascade the obtained bits, and repeat this operation until Qm bits are cascaded.
Optionally, the processor 51 is further configured to encode the segmented code blocks to obtain encoded code blocks.
The processor 51 is further configured to perform interleaving processing on the encoded code blocks by using an interleaver, to obtain interleaved code blocks.
The processor 51 is further configured to perform rate matching on the interleaved code blocks to obtain the output code blocks.
Optionally, the processor 51 is further configured to perform data modulation on the cascaded code blocks to obtain modulated data.
The processor 51 is further configured to perform digital-to-analog conversion on the modulated data to obtain analog data.
The transmitter 52 is further configured to send the analog data to the terminal device.
The base station provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the base station are similar to those of the data transmission method, and details are not described herein again.
The processor 61 is configured to segment, according to a preset parameter, a code block corresponding to data, to obtain segmented code blocks.
The processor 61 is further configured to perform encoding processing on the segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks.
The processor 61 is further configured to perform interleaving processing on the system bit code blocks according to a quantity of symbol bits in a constellation diagram, to obtain interleaved code blocks.
The processor 61 is further configured to cascade the interleaved code blocks to obtain cascaded code blocks.
The transmitter 62 is configured to send the cascaded code blocks to a terminal device.
The base station provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the base station are similar to those of the data transmission method, and details are not described herein again.
Optionally, the processor 61 is further configured to determine a segment quantity, a length of a segmented code block, and a quantity of first padding bits according to the preset parameter, where the padding bit is a bit used when bit padding is performed on the code block.
The processor 61 is further configured to perform bit padding on the code block according to the segment quantity, the length of a segmented code block, and the quantity of first padding bits, so as to segment the code block.
Optionally, the processor 61 is further configured to determine a quantity of rows of an interleaver according to the quantity of symbol bits in the constellation diagram, and determine a quantity of second padding bits according to the quantity of rows of the interleaver and a preset quantity of columns of the interleaver.
The processor 61 is further configured to separately place the padding bit and an information bit according to the quantity of second padding bits and the quantity of symbol bits in the constellation diagram, where the information bit is a bit corresponding to the data.
The base station provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the base station are similar to those of the data transmission method, and details are not described herein again.
The receiver 71 is configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a quantity of symbol bits in a constellation diagram, rate matching is performed on the segmented code blocks obtained by channel encoding to obtain output code blocks, and the output code blocks are cascaded according to the quantity of symbol bits in the constellation diagram.
The processor 72 is configured to perform code block splitting on the cascaded code blocks according to the quantity of symbol bits in the constellation diagram, to obtain split code blocks.
The processor 72 is further configured to perform code block cascading on the split code blocks obtained by channel decoding, to obtain the data.
The terminal device provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the terminal device are similar to those of the data transmission method, and details are not described herein again.
Optionally, the processor 72 is further configured to use every Qm/2 bits in the cascaded code blocks as a bit group, sequentially obtain one bit from each bit group, and form a bit stream by using the obtained bits.
Optionally, the processor 72 is further configured to perform de-interleaving processing on the split code blocks by using a de-interleaver, to obtain de-interleaved code blocks.
The processor 72 is further configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks.
The processor 72 is further configured to sequentially perform CRC check and code block cascading processing on the decoded code blocks, to obtain the data.
The terminal device provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the terminal device are similar to those of the data transmission method, and details are not described herein again.
The receiver 81 is configured to receive cascaded code blocks sent by a base station, where the cascaded code blocks are obtained after a code block corresponding to data is segmented according to a preset parameter, encoding processing is performed on the obtained segmented code blocks to obtain encoded code blocks, where the encoded code blocks include system bit code blocks, interleaving processing is performed on the system bit code blocks according to a quantity of symbol bits in a constellation diagram to obtain interleaved code blocks, and the interleaved code blocks are cascaded.
The processor 82 is configured to perform LTE data receiving processing on the cascaded code blocks to obtain check code blocks.
The processor 82 is further configured to perform row-in-column-out code block cascading on the check code blocks to obtain cascaded code blocks.
The terminal device provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the terminal device are similar to those of the data transmission method, and details are not described herein again.
Optionally, the processor 82 is further configured to perform code block splitting on the cascaded code blocks to obtain split code blocks.
The processor 82 is further configured to perform de-interleaving processing on the split code blocks to obtain de-interleaved code blocks.
The processor 82 is further configured to perform decoding processing on the de-interleaved code blocks to obtain decoded code blocks.
The processor 82 is further configured to check the decoded code blocks to obtain the check code blocks.
The terminal device provided in this embodiment may be configured to execute the technical solution of the data transmission method based on unequal error protection provided in any embodiment of the present invention. An implementation principle and a technical effect of the terminal device are similar to those of the data transmission method, and details are not described herein again.
It may be clearly understood by a person skilled in the art that, for the purpose of convenient and brief description, division of the foregoing function modules is taken as an example for illustration. In actual application, the foregoing functions can be allocated to different function modules and implemented according to a requirement, that is, an inner structure of an apparatus is divided into different function modules to implement all or some of the functions described above. For a detailed working process of the foregoing system, apparatus, and unit, reference may be made to a corresponding process in the foregoing method embodiments, and details are not described herein again.
In the several embodiments provided in this application, it should be understood that the disclosed system, apparatus, and method may be implemented in other manners. For example, the described apparatus embodiment is merely an example. For example, the module or unit division is merely logical function division and may be other division in actual implementation. For example, a plurality of units or components may be combined or integrated into another system, or some features may be ignored or not performed. In addition, the displayed or discussed mutual couplings or direct couplings or communication connections may be implemented by using some interfaces. The indirect couplings or communication connections between the apparatuses or units may be implemented in electronic, mechanical, or other forms.
The units described as separate parts may or may not be physically separate, and parts displayed as units may or may not be physical units, may be located in one position, or may be distributed on a plurality of network units. Some or all of the units may be selected according to actual requirements to achieve the objectives of the solutions of the embodiments.
In addition, functional units in the embodiments of this application may be integrated into one processing unit, or each of the units may exist alone physically, or two or more units are integrated into one unit. The integrated unit may be implemented in a form of hardware, or may be implemented in a form of a software functional unit.
When the integrated unit is implemented in the form of a software functional unit and sold or used as an independent product, the integrated unit may be stored in a computer-readable storage medium. Based on such an understanding, the technical solutions of this application essentially, or the part contributing to the prior art, or all or a part of the technical solutions may be implemented in the form of a software product. The software product is stored in a storage medium and includes several instructions for instructing a computer device (which may be a personal computer, a server, or a network device) or a processor (processor) to perform all or a part of the steps of the methods described in the embodiments of this application. The foregoing storage medium includes: any medium that can store program code, such as a USB flash drive, a removable hard disk, a read-only memory (ROM, Read-Only Memory), a random access memory (RAM, Random Access Memory), a magnetic disk, or an optical disc.
The foregoing embodiments are merely intended for describing the technical solutions of this application, but not for limiting this application. Although this application is described in detail with reference to the foregoing embodiments, a person of ordinary skill in the art should understand that they may still make modifications to the technical solutions described in the foregoing embodiments or make equivalent replacements to some technical features thereof, without departing from the spirit and scope of the technical solutions of the embodiments of this application.
This application is a continuation of International Application No. PCT/CN2015/084374, filed on Jul. 17, 2015, the disclosure of which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2015/084374 | Jul 2015 | US |
Child | 15864201 | US |