The disclosure relates to a coding technology of digital communication, and in particular to a method and apparatus for supporting low bit rate coding, and a computer storage medium.
As wireless digital communication develops and various services with high rate and strong abruptness emerge, people make much higher demands for an error correction coding technology. Low Density Parity Check (LDPC) Codes are a class of linear packet codes which can be defined by a very sparse parity check matrix or a bipartite graph. The LDPC codes were discovered by Gallager initially, so they are called Gallager codes. After decades of silence, as computer hardware and relevant theories develop, MacKay and Neal re-discover the Gallager codes and prove that the Gallager codes have properties approaching a Shannon limit. The latest research shows that the LDPC codes are characterized by being low in decoding complexity, capable of linear time coding and parallel decoding, and superior to Turbo codes under the condition of large code length, and having properties approaching the Shannon limit.
The LDPC codes are linear packet codes based on sparse parity check matrices, and low-complexity coding and decoding can be achieved using the sparseness of the parity check matrices, such that the LDPC codes tend to be practical. Irregular codes refer to LDPC codes of which parity check matrices have totally different row weights and column weights, and column weights of information bit parts of the parity check matrices are also different. Regular codes refer to LDPC codes of which parity check matrices have identical row weights and column weights. In related articles, someone calls the LDPC codes, under a second situation, in the regular codes as semi-regular codes. The frequency distribution of a basic parity check matrix is consistent with that of a parity check matrix.
The LDPC codes are special liner packet codes. In communication, every time a code word of which the packet length is N bits, M check bits are needed in order to ensure that the code word has a certain error correcting capability, and each code word is required to meet HxT=0T, where H is an M×N-dimension parity check matrix on a binary field, and xT is a 1×N sequence. All operations are carried out on a binary field GF(2). Here, addition and subtraction operations are exclusive-OR operations, and a multiplication operation is an AND operation.
The parity check matrix H of a structured LDPC code is set as an (M×z)×(N×z) matrix which is composed of M×N block matrices. Each block matrix is different powers of a z×z basic permutation matrix, and when the basic permutation matrix is a unit matrix, each block matrix is a cyclic shift matrix (right shift herein in default) of the unit matrix. Each block matrix can be uniquely identified by a power j, the power of the unit matrix can be represented by 0, and the matrix is represented by −1 generally. Thus, if each block matrix of H is replaced with a power thereof, an M×N power matrix Hb is obtained. Here, Hb is defined as a basic parity check matrix of H, H being called as a parity check matrix of Hb. During practical coding, z is equal to a value obtained by dividing a code length by a column number N of a basic parity check matrix, which is called as an expansion factor.
For instance, a matrix
can be obtained by expansion using a parameter z and a 2×4 basic parity check matrix Hb, wherein
z=3, and
Thus, that is to say, a coder for an LDPC code is generated by a basic parity check matrix Hb, an expansion factor z and a selected basic permutation matrix. According to a definition of the above basic parity check matrix, it can be seen that the basic parity check matrix and the parity check matrix are consistent essentially under the condition that an expansion factor (an integer z greater than 1) is given.
A direct LDPC coding method refers to: dividing a code word x into N−M information bits s and M check bits c, and accordingly, dividing an M×N parity check matrix H into an M×(N−M) block corresponding to the information bits and an M×M block corresponding to the check bits respectively, that is, H=[A|B], A and B being blocks. According to H×x=0, the following formula can be obtained:
So, A×s+B×c=0 can be obtained, and c=B−1As is further derived. When the block B adopts a special matrix structure such as a strictly lower triangular matrix (semi-random matrix) and a doubly lower triangular structure, B−1 has a very simple form, a check bit part c in the code word can be directly calculated in accordance with the above formula, and it can be ensured that the coder has linear complexity.
LDPC coding can also adopt a Richarson linear time coding algorithm: a parity check matrix H has a quasi-lower triangular structure, and given that H has the following form:
Given that a coded code word is x=(s,p1,p2). Here, s is a system bit part of the coded code word, p1 and p2 are check bit parts of the code word, the length of p1 is g, and the length of p2 is (m−g). In the above formula, the dimensionality of A is (m−g)×(n−m), the dimensionality of B is (m−g)×g, the dimensionality of T is (m−g)×(m−g), the dimensionality of C is g×(n−m), the dimensionality of D is g×g, and the dimensionality of E is g×(m−g). All these matrices are sparse matrices, T is a lower triangular matrix, and all main diagonal elements are 1. The check bit part can be obtained by the following formulae:
p1T=−φ−1(−ET−1A+C)sT
p2T=−T−1(AsT+Bp1T), where φ=−ET−1B+D.
It is crucial to search for an appropriate LDPC code parity check matrix structure. During specific implementation, a direct method or a Richarson method or other methods can be adopted for operation so as to complete coding of N bit code words from N−M bit source data. Actually, the coder achieves multiplication and addition operations for a sparse matrix in the formula using software or hardware. The multiplication operation for the sparse matrix can be composed of a plurality of z-bit (z being an expansion factor) cyclic shift registers and a plurality of z-bit adders, for LDPC codes based on unit matrices and cyclic shift matrices thereof. The addition operation for the sparse matrix is completed by the plurality of z-bit adders. The plurality of z-bit cyclic shift registers and the plurality of z-bit adders construct an LDPC coder implemented by a hardware circuit.
There are multiple LDPC decoding methods such as a probability domain BP decoding algorithm, a log domain BP decoding algorithm and a layered min-sum decoding algorithm. The probability domain BP decoding algorithm has the best performance. However, the disadvantages of the probability domain BP decoding algorithm lie in that the needed hardware cost is very high and a dynamic range of a numerical value is large and low in stability due to the fact that a great number of multiplication operations are involved and the operation quantity is large, so the probability domain BP decoding algorithm cannot be used usually in practical application. Compared with the probability domain BP decoding algorithm, the log domain BP decoding algorithm reduces lots of calculation units, but many multiplication operations are also needed, so the needed hardware cost is also high. The layered min-sum decoding algorithm transforms key calculation (log operation and multiplication operation) units of the log domain BP decoding algorithm into calculation of a minimum value and a secondary minimum value, needed hardware resources are greatly reduced, the performance will be slightly lost, and many hardware resources can be reduced. Consequently, the layered min-sum decoding algorithm is more frequently adopted in practical application.
A structured LDPC code decoder has inherent decoding parallelism, so the decoding speed is high, the throughput is high, and the decoding performance quite approaches the Shannon limit.
In various current communication modes, control signalling data will be coded with a lower bit rate so as to improve transmission reliability, or important data parts will adopt a lower bit rate coding mode to guarantee data correctness. However, various current communication systems obtain a lower bit rate implementation mode in a simple rate matching mode via higher bit rate LDPC codes. Thus, it is difficult to fully utilize coding gains, which causes poor performance of the coding and decoding system. So, an LDPC code coding method supporting a low bit rate is urgently needed now.
In order to solve the existing technical problems, the disclosure expects to provide a method and apparatus for supporting low bit rate coding, and a computer storage medium.
The technical solutions of the embodiments of the disclosure are implemented as follows.
An apparatus for supporting low bitrate coding, provided by an embodiment of the disclosure, at least includes: a repeater and a coder, wherein
the repeater is configured to repeat a source data packet to be coded for i times, i being a positive integer; and
the coder is configured to code the data packet repeated by the repeater, coding being LDPC coding, Turbo coding or convolutional coding.
A method for supporting low code bit coding, provided by an embodiment of the disclosure, at least includes that:
a source data packet to be coded is repeated for i times, and the data packet which is repeated for i times is coded, wherein i is a positive integer, and
coding is LDPC coding, Turbo coding or convolutional coding.
An embodiment of the disclosure also provides a computer storage medium. A computer program is stored therein and is configured to execute the above method for supporting low bit rate coding.
The embodiments of the disclosure provide a method and apparatus for supporting low bit rate coding, and a computer storage medium. A source data packet to be coded is repeated for i times, and the data packet which is repeated for i times is coded. Thus, low bit rate coding can be achieved. By repeating the source data packet to be coded for several times and then coding the data packet, coding gains can be fully utilized, and the coding and decoding performances of a coding and decoding system under a lower bit rate are improved.
The basic idea of the disclosure is that: a source data packet to be coded is repeated for i times, and the data packet which is repeated for i times is coded. Thus, low bit rate coding can be achieved, and coding gains can be fully utilized.
The disclosure is further illustrated below with reference to the drawings and specific embodiments in detail.
The embodiment of the disclosure implements an apparatus for supporting low bit rate coding. As shown in
the repeater 102 is configured to repeat a k-bit source data packet x to be coded for i times, i being a positive integer; and
the coder 104 is configured to code the data packet repeated by the repeater 102, coding being LDPC coding, Turbo coding or convolutional coding.
The repeater 102 is specifically configured to directly repeat the source data packet x to be coded for i times, or the source data packet x includes j sub-data packets, the j sub-data packets are repeated for i times respectively, j is a positive integer, and i may be 1, 2, 3, 4, 5 or 6 generally.
Specifically, the coder 104 is an (nb×z, kb×z) LDPC coder, and a master code data packet C′ is obtained by coding, where nb is a column number of a basic parity check matrix, z is an expansion factor, z, nb and kb are positive integers, kb=nb−mb, mb is a row number of the basic parity check matrix, and mb is a positive integer. Before the coder 104 carries out coding, the basic parity check matrix is read, and then values of r non −1 element in the basic parity check matrix are set as −1, where r is an integer which is greater than or equal to 0 and is smaller than r0, and r0 is the number of non −1 elements in an original basic parity check matrix.
The apparatus may further include a rate matcher 106, configured to carry out rate matching on the master code data packet C′ so as to obtain an N-bit coded data packet, N being a code length.
The working process of the apparatus for supporting low bit rate LDPC code coding according to the present embodiment is illustrated below by means of four specific examples.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. The coder 104 is a (16×42, 8×42) LDPC coder, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a71] (k=72 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=1024 bits), the repeater 102 repeats the signalling sequence a for one time, and then expands to obtain a 336-bit data packet d=[(d0, d1, . . . , d335], d being as follows:
di=ai-180 i=180,181, . . . ,209
di=ai-222 i=222,223, . . . ,293
di=ai-264 i=294,295, . . . ,335;
di=0 i=others
the coder 104 carries out LDPC coding on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and combines the signalling sequence a and the 336-bit check data packet b into a 408-bit master code data packet s=[a,b]=[s0, s1, . . . , s407]; and
the rate matcher 106 constructs a 1024-bit coded data packet e by the master code data packet s, e being:
ej=sj j=0,1, . . . , 407
ej=sj-408 j=408,409, . . . , 815
ej=sj-816 j=816,817, . . . , 1023.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. The coder 104 is a (16×42, 8×42) LDPC coder, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a79] (k=80 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=672 bits), the repeater 102 repeats the signalling sequence a for one time, and then expands to obtain a 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
the coder 104 carries out LDPC coding on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and combines the signalling sequence a and the 336-bit check data packet b into a 416-bit master code data packet s=[a,b]=[s0, s1, . . . , s415]; and
the rate matcher 106 constructs a 672-bit coded data packet e by the master code data packet s, e being:
ej=sj j=0,1, . . . , 415
ej=sj-416 j=416,417, . . . , 671.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. The coder 104 is a (16×42, 8×42) LDPC coder, the basic parity check matrix is an 8×16 matrix, the expansion factor z=42, a source data packet to be coded is a signalling sequence f=[f0, f1, . . . , f39] (k=40 bits), and when LDPC coding is carried out on the signalling sequence f using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet h (n=672 bits), the repeater 102 repeats the signalling sequence f for one time, and then expands to obtain a 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=fi-254 i=254,255, . . . ,293
di=fi-296 i=296,297, . . . ,335;
di=0 i=others
the coder 104 carries out LDPC coding on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and combines the signalling sequence a and the 336-bit check data packet b into a 376-bit master code data packet g=[f,b]=[g0, g1, . . . , g375]; and
the rate matcher 106 constructs a 672-bit coded data packet h by the master code data packet g, h being:
hj=gj i=0,1, . . . ,375
hj=gj-376 i=376,417, . . . ,671
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. The coder 104 is a (16×42, 8×42) LDPC coder, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a79] (k=80 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=672 bits), the repeater 102 repeats the signalling sequence a for one time, and then expands to obtain a 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
the coder 104 modifies an element ‘0’ in the second row and the sixth column in the basic parity check matrix into ‘−1’ first. The modified basic parity check matrix is as follows:
the coder 104 carries out LDPC coding on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and combines the signalling sequence a and the 336-bit check data packet b into a 416-bit master code data packet s=[a,b]=[s0, s1, . . . , s415]; and
the rate matcher 106 constructs a 672-bit coded data packet e by the master code data packet s, e being:
ej=sj j=0,1, . . . , 415
ej=sj-416 j=416,417, . . . , 671.
The embodiment of the disclosure implements an apparatus for supporting low bit rate coding. As shown in
the repeater 102 is configured to repeat a k-bit source data packet x to be coded for i times, i being a positive integer; and
the coder 104 is configured to code the data packet repeated by the repeater 102, coding being LDPC coding, Turbo coding or convolutional coding.
Specifically, the coder 104 is an (nb×z, kb×z) LDPC coder, and a check data packet P is obtained by coding, where nb is a column number of a basic parity check matrix, (nb−kb) is a row number of the basic parity check matrix, z is an expansion factor, and z, nb and kb are positive integers. Before the coder 104 carries out coding, the basic parity check matrix is read, and then values of r non −1 element in the basic parity check matrix are set as −1, where r is an integer which is greater than or equal to 0 and is smaller than r0, and r0 is the number of non −1 elements in an original basic parity check matrix.
The apparatus may further include a master code generator 105, the master code generator 105 combines the check data packet P, obtained by the coder 104, and the source data packet x into a master code data packet C′, and an N-bit coded data packet can be obtained by carrying out rate matching on the master code data packet C′ via a rate matcher 106, N being a code length.
The apparatus may further include a first-class filler 101, configured to fill the source data packet x to be coded with q1 elements so as to obtain a first data packet x0 by expansion, q1 being a positive integer.
The repeater 102 directly repeats the first data packet x0 for i times, or the first data packet x0 is split into j sub-data packets, the j sub-data packets are repeated for i times respectively, j is a positive integer, and i may be 1, 2, 3, 4, 5 or 6 generally.
The apparatus can fill the data packet repeated by the repeater 102 with q2 elements via a second-class filler 103 so as to obtain a second data packet Y, q2 being a positive integer.
The apparatus may further include the rate matcher 106, configured to carry out rate matching on the master code data packet C so as to obtain the N-bit coded data packet, N being a code length.
The working process of the apparatus for supporting low bit rate LDPC code coding according to the present embodiment is illustrated below by means of two specific examples.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. The coder 104 is a (16×42, 8×42) LDPC coder, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a79] (k=80 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=672 bits), there are two processing modes.
In the first mode, when there is not a first-class filler 101,
the repeater 102 repeats the signalling sequence a for one time, and then expands to obtain a 168-bit data packet;
the second-class filler 103 fills the data packet repeated by the repeater 102 with 168 bit elements, and expands to obtain a second 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di==0 i=others
the coder 104 carries out LDPC coding on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335];
the master code generator 105 combines the signalling sequence a and the 336-bit check data packet b into a 416-bit master code data packet s=[a, b]=[s0, s1, . . . , s415]; and
the rate matcher 106 constructs a 672-bit coded data packet e by the master code data packet s, e being:
ej=sj j=0,1, . . . ,415
ej=sj-416 j=416,417, . . . ,671.
In the second mode, when there is a first-class filler 101,
the first-class filler 101 fills the signalling sequence a with 4 bit elements into a first 84-bit data packet;
the repeater 102 splits the first data packet into two 42-bit sub-data packets, and then repeats each sub-data packet for one time respectively;
the second-class filler 103 fills the data packet repeated by the repeater 102 with 168 bit elements, and expands to obtain a second 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
the coder 104 carries out LDPC coding on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335];
the master code generator 105 combines the signalling sequence a and the 336-bit check data packet b into a 416-bit master code data packet s=[a, b]=[s0, s1, . . . , s415]; and
the rate matcher 106 constructs a 672-bit coded data packet e by the master code data packet s, e being:
ej=sj j=0,1, . . . ,415
ej=sj-416 j=416,417, . . . ,671.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. The coder 104 is a (16×42, 8×42) LDPC coder, the basic parity check matrix is an 8×16 matrix, the expansion factor z=42, a source data packet to be coded is a signalling sequence f=[f0, f1, . . . , f39] (k=40 bits), and when LDPC coding is carried out on the signalling sequence f using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet h (n=672 bits), there are two processing modes.
In the first mode, when there is not a first-class filler 101,
the repeater 102 repeats the signalling sequence f for one time, and then expands to obtain an 84-bit data packet;
the second-class filler 103 fills the data packet expanded by the repeater 102 with 252 bit elements, and expands to obtain a second 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=fi-254 i=254,255, . . . ,293
di=fi-296 i=296,297, . . . ,335;
di==0 i=others
the coder 104 carries out LDPC coding on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335];
the master code generator 105 combines the signalling sequence a and the 336-bit check data packet b into a 376-bit master code data packet g=[f,b]=[g0, g1, . . . , g375]; and
the rate matcher 106 constructs a 672-bit coded data packet h by the master code data packet g, h being:
hj=gj i=0,1, . . . ,375
hj=gj-376 i=376,417, . . . ,671.
In the second mode, when there is a first-class filler 101,
the first-class filler 101 fills the signalling sequence f with 2 bit elements into a first 42-bit data packet;
the repeater 102 repeats the first data packet for one time;
the second-class filler 103 fills the data packet repeated by the repeater 102 with 252 bit elements, and expands to obtain a second 336-bit data packet d=[d0, d1, . . . , d335], d being as follows:
di=fi-254 i=254,255, . . . ,293
di=fi-296 i=296,297, . . . ,335;
di=0 i=others
the coder 104 carries out LDPC coding on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335];
the master code generator 105 combines the signalling sequence a and the 336-bit check data packet b into a 376-bit master code data packet g=[f,b]=[g0, g1, . . . , g375]; and
the rate matcher 106 constructs a 672-bit coded data packet h by the master code data packet g, h being:
hj=gj i=0,1, . . . ,375
hj=gj-376 i=376,417, . . . ,671.
Based on the apparatus, the embodiment of the disclosure also implements a method for supporting low bit rate coding. As shown in
Step 301: A source data packet to be coded is repeated for i times, i being a positive integer.
Repeating the source data packet to be coded for i times can be implemented in two modes, and in the first mode, the source data packet to be coded is directly repeated for i times; and
in the second mode, the source data packet includes j sub-data packets, the j sub-data packets are repeated for i times respectively, j is a positive integer, and i may be 1, 2, 3, 4, 5 or 6 generally.
Step 302: The data packet repeated for i times is coded, coding being LDPC coding, Turbo coding or convolutional coding.
Here, coding may adopt (nb×z, kb×z) LDPC coding, and a master code data packet is obtained by coding, where nb is a column number of a basic parity check matrix, (nb−kb) is a row number of the basic parity check matrix, z is an expansion factor, and z, nb and kb are positive integers greater than 0. Before LDPC codes are coded, the basic parity check matrix is read, and then values of r non −1 element in the basic parity check matrix are set as −1, where r is an integer which is greater than or equal to 0 and is smaller than r0, and r0 is the number of non −1 elements in an original basic parity check matrix.
The check data packet will be obtained after Step 202, the method further includes that: rate matching is carried out on the master code data packet so as to obtain an N-bit coded data packet, N being a positive integer representative of a code length.
The steps of the method for supporting low bit rate LDPC code coding according to the present embodiment are illustrated below by means of four specific examples.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. (16×42, 8×42) LDPC coding is adopted, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a71] (k=72 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=1024 bits), the signalling sequence a is repeated for one time, and a 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=ai-180 i=180,181, . . . ,209
di=ai-222 i=222,223, . . . ,293
di=ai-264 i=294,295, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 408-bit master code data packet s=[a,b]=[s0, s1, . . . , s407]; and
finally, a 1024-bit coded data packet e is constructed by the master code data packet s, e being:
ej=sj j=0,1, . . . ,407
ej=sj-408 j=408,409, . . . ,815
ej=sj-816 j=816,817, . . . ,1023.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. (16×42, 8×42) LDPC coding is adopted, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a79] (k=80 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=672 bits), the signalling sequence a is repeated for one time, and a 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 416-bit master code data packet s=[a, b]=[s0, s1, . . . , s415]; and
finally, a 672-bit coded data packet e is constructed by the master code data packet s, e being:
ej=sj j=0,1, . . . ,415
ej=sj-416 j=416,417, . . . ,671.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. (16×42, 8×42) LDPC coding is adopted, the basic parity check matrix is an 8×16 matrix, the expansion factor z=42, a source data packet to be coded is a signalling sequence f=[f0, f1, . . . , f39] (k=40 bits), and when LDPC coding is carried out on the signalling sequence f using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet h (n=672 bits), the signalling sequence f is repeated for one time, and a 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=fi-254 i=254,255, . . . ,293
di=fi-296 i=296,297, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 376-bit master code data packet g=[f,b]=[g0, g1, . . . , g375]; and finally, a 672-bit coded data packet h is constructed by the master code data packet g, h being:
hj=gj i=0,1, . . . ,375
hj=gj-376 i=376,417, . . . ,671.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. (16×42, 8×42) LDPC coding is adopted, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a79] (k=80 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=672 bits), the signalling sequence a is repeated for one time, and a 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
then, an element ‘0’ in the second row and the sixth column in the basic parity check matrix is modified into ‘−1’ first, and the modified basic parity check matrix is as follows:
LDPC coding is carried out on the data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 416-bit master code data packet s=[a,b]=[s0, s1, . . . , s415]; and
finally, a 672-bit coded data packet e is constructed by the master code data packet s, e being:
ej=sj j=0,1, . . . ,415
ej=sj-416 j=416,417, . . . ,671.
The embodiment of the disclosure implements a method for supporting low bit rate coding. The basic steps are the same as those of the third embodiment. In the present embodiment, before Step 301, a first data packet can be obtained by filling a source data packet to be coded with q1 elements and then expanding, q1 being a positive integer.
Here, repeating the source data packet to be coded for i times can be implemented in two modes, and in the first mode, the first data packet is directly repeated for i times; and
in the second mode, the first data packet is split into j sub-data packets, each sub-data packet is repeated for i times respectively, j is a positive integer, and i may be 1, 2, 3, 4, 5 or 6 generally.
The method according to the present embodiment further includes that: the data packet repeated for i times is filled with q2 elements so as to obtain a second data packet by expansion.
According to the present embodiment, in Step 302, (nb×z, kb×z) LDPC coding is adopted, and a check data packet is obtained by coding, where nb is a column number of a basic parity check matrix, (nb−kb) is a row number of the basic parity check matrix, z is an expansion factor, and z, nb and kb are positive integers greater than 0. Before LDPC codes are coded, the basic parity check matrix is read, and then values of r non −1 element in the basic parity check matrix are set as −1, where r is an integer which is greater than or equal to 0 and is smaller than r0, and r0 is the number of non −1 elements in an original basic parity check matrix.
The method according to the present embodiment further includes that: the check data packet and the source data packet are combined into a master code data packet, and after the master code data packet is obtained, an N-bit coded data packet can be obtained by carrying out rate matching on the master code data packet.
The steps of the method for supporting low bit rate LDPC code coding according to the present embodiment are illustrated below by means of two specific examples.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. (16×42, 8×42) LDPC coding is adopted, a source data packet to be coded is a signalling sequence a=[a0, a1, a2, . . . , a79] (k=80 bits), and when LDPC coding is carried out on the signalling sequence a using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet e (n=672 bits), there are two processing modes.
In the first mode,
firstly, the signalling sequence a is repeated for one time, and a 168-bit data packet is obtained by expansion;
then, the data packet is filled with 168 bit elements, and a second 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 416-bit master code data packet s=[a,b]=[s0, s1, . . . , s415]; and
finally, a 672-bit coded data packet e is constructed by the master code data packet s, e being:
ej=sj j=0,1, . . . ,415
ej=sj-416 j=416,417, . . . ,671.
In the second mode,
firstly, the signalling sequence a is filled with 4 bit elements to expand into a first 84-bit data packet, the first data packet is split into two 42-bit sub-data packets, and then each sub-data packet is repeated for one time respectively;
then, the repeated data packet is filled with 168 bit elements, and a second 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=ai-172 i=172,173, . . . ,209
di=ai-214 i=214,215, . . . ,293
di=ai-256 i=294,295, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 416-bit master code data packet s=[a,b]=[s0, s1, . . . , s415]; and
finally, a 672-bit coded data packet e is constructed by the master code data packet s, e being:
ej=sj j=0,1, . . . ,415
ej=sj-416 j=416,417, . . . ,671.
Given that a basic parity check matrix Hb8×16 is as follows:
A bit rate corresponding to the shown basic parity check matrix Hb8×16 is 1/2, an expansion factor z=42, a matrix row number is 8, a matrix column number is 16, numbers shown in left is row indexes, uppermost numbers are column indexes, a letter ‘A’ represents a system bit part matrix, and a letter ‘B’ represents a check bit part matrix. (16×42, 8×42) LDPC coding is adopted, the basic parity check matrix is an 8×16 matrix, the expansion factor z=42, a source data packet to be coded is a signalling sequence f=[f0, f1, . . . , f39] (k=40 bits), and when LDPC coding is carried out on the signalling sequence f using a 1/2 bit rate LDPC code basic parity check matrix to obtain a coded data packet h (n=672 bits), there are two processing modes.
In the first mode,
firstly, the signalling sequence f is repeated for one time, and an 84-bit data packet is obtained by expansion; the data packet is filled with 252 bit elements, and a second 336-bit data packet d=[d0, d1, . . . , d335] is obtained, d being as follows:
di=fi-254 i=254,255, . . . ,293
di=fi-296 i=296,297, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335], the signalling sequence a and the 336-bit check data packet b are combined into a 376-bit master code data packet g=[f,b]=[g0, g1, . . . , g375]; and
finally, a 672-bit coded data packet h is constructed by the master code data packet g, h being:
hj=gj i=0,1, . . . ,375
hj=gj-376 i=376,417, . . . ,671.
In the second mode,
firstly, the signalling sequence f is filled with 2 bit elements to expand into a first 42-bit data packet, and the first data packet is repeated for one time;
then, the repeated data packet is filled with 252 bit elements, and a second 336-bit data packet d=[d0, d1, . . . , d335] is obtained by expansion, d being as follows:
di=fi-254 i=254,255, . . . ,293
di=fi-296 i=296,297, . . . ,335;
di=0 i=others
then, LDPC coding is carried out on the second data packet d to obtain a check data packet b=[b0, b1, . . . , b335], and the signalling sequence a and the 336-bit check data packet b are combined into a 376-bit master code data packet g=[f,b]=[g0, g1, . . . , g375]; and
finally, a 672-bit coded data packet h is constructed by the master code data packet g, h being:
hj=gj i=0,1, . . . ,375
hj=gj-376 i=376,417, . . . ,671.
If the method for supporting low bit rate coding in the embodiment of the disclosure is implemented in a form of a software function module and when being sold or used as an independent product, the product may also be stored in a computer readable storage medium. Based on this understanding, those skilled in the art shall understand that the embodiments of the disclosure may be provided as a method, a system or a computer program product. Thus, forms of complete hardware embodiments, complete software embodiments or embodiments integrating software and hardware may be adopted in the disclosure. Moreover, a form of the computer program product implemented on one or more computer available storage media containing computer available program codes may be adopted in the disclosure. The storage media include, but are not limited to, a U disk, a mobile hard disk, a Read-Only Memory (ROM), a magnetic disk memory, a CD-ROM, an optical memory and the like.
The disclosure is described with reference to flowcharts and/or block diagrams of the method, the device (system) and the computer program product according to the embodiments of the disclosure. It will be appreciated that each flow and/or block in the flowcharts and/or the block diagrams and combination of the flows and/or the blocks in the flowcharts and/or the block diagrams may be implemented by computer program instructions. These computer program instructions may be provided to a general computer, a dedicated computer, an embedded processor or processors of other programmable data processing devices to generate a machine, such that an apparatus for implementing functions designated in one or more flows of the flowcharts and/or one or more blocks of the block diagrams is generated via instructions executed by the computers or the processors of the other programmable data processing devices.
These computer program instructions may also be stored in a computer readable memory capable of guiding the computers or the other programmable data processing devices to work in a specific mode, such that a manufactured product including an instruction apparatus is generated via the instructions stored in the computer readable memory, and the instruction apparatus implements the functions designated in one or more flows of the flowcharts and/or one or more blocks of the block diagrams.
These computer program instructions may also be loaded to the computers or the other programmable data processing devices, such that processing implemented by the computers is generated by executing a series of operation steps on the computers or the other programmable devices, and therefore the instructions executed on the computers or the other programmable devices provide a step of implementing the functions designated in one or more flows of the flowcharts and/or one or more blocks of the block diagrams.
Accordingly, an embodiment of the disclosure also provides a computer storage medium. A computer program is stored therein and is configured to execute the method for supporting low bit rate coding according to the embodiment of the disclosure.
The above is only the preferred embodiments of the disclosure and is not used to limit the protective scope of the disclosure.
All the embodiments of the disclosure are integrated. By repeating a source data packet to be coded for several times and then coding the data packet, coding gains can be fully utilized, and the coding and decoding performances of a coding and decoding system under a lower bit rate are improved.
Number | Date | Country | Kind |
---|---|---|---|
2014 1 0087934 | Mar 2014 | CN | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/CN2014/085228 | 8/26/2014 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2015/135298 | 9/17/2015 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6868156 | Narayan | Mar 2005 | B1 |
20050110286 | Zhang | May 2005 | A1 |
20050246616 | Choi | Nov 2005 | A1 |
20080204286 | Kose | Aug 2008 | A1 |
20090106620 | Yokokawa | Apr 2009 | A1 |
20110085609 | Kasher | Apr 2011 | A1 |
20110289375 | Jiang | Nov 2011 | A1 |
20110307755 | Livshitz | Dec 2011 | A1 |
20130073927 | Kasher | Mar 2013 | A1 |
20130311850 | Shinohara | Nov 2013 | A1 |
Number | Date | Country |
---|---|---|
1622649 | Jun 2005 | CN |
101047387 | Oct 2007 | CN |
101136638 | Mar 2008 | CN |
101442315 | May 2009 | CN |
101442315 | May 2009 | CN |
101453220 | Jun 2009 | CN |
101488760 | Jul 2009 | CN |
101499804 | Aug 2009 | CN |
101635573 | Jan 2010 | CN |
101924565 | Dec 2010 | CN |
102611465 | Jul 2012 | CN |
103152058 | Jun 2013 | CN |
1837999 | Sep 2007 | EP |
20070046477 | May 2007 | KR |
2011043871 | Apr 2011 | WO |
Entry |
---|
English Translation of the Written Opinion of the International Search Authority in international application No. PCT/CN2014/085228, dated Dec. 1, 2014 , 11 pgs. |
International Search Report in international application No. PCT/CN2014/085228, dated Dec. 1, 2014, 6 pgs. |
English Translation of the Written Opinion of the International Search Authority in international application No. PCT/CN2014/085228, dated Dec. 1, 2014, 15 pgs. |
Supplementary European Search Report in European application No. 14885292.4, dated Feb. 17, 2017, 12 pgs. |
“Performance Evaluation of Low Density Parity Check Codes for IEEE 802.11n and Its ASIC Design”, W.A.Syafei, Y. Nagao, R. Yohena, H. Shimajiri, T. Yoshida, M. Kurosaki, B.Saj and H. Ochi, Oct. 2008, Proc. , IEEE International Symposium on Communications and Information Technologies, ISCIT 2008, pp. 609-614. |
“Construction of multiple-rate QC-LDPC codes with constant block lengths” Wang Qi, Xie Qiuliang and Wang, Zhaocheng, 2013, China Academic Journal, J. Tsinghus University (Sci & Tech), vol. 53, No. 3, Abstract in English, 5 pgs. |
“Design and implementation of a high throughput decoder for multi-rate LDPC code”, Guanwu, Qiao Hua, Dong Ming-Ke and Ziang Hai-Ge, Apr. 2009, Journal of Circuits and Systems, vol. 14, No. 2, 6 pgs. Abstract in English. |
“Optimized extension of the parity-check matrix for rate-compatible LDPC codes” Chenzi-Qiang, Ouyang Shan, Li Min-Zheng, Zang Lan and Xiao Hai-Lin, Sep. 2013, Systems Engineering and Electronics, vol. 35, No. 9, 5 pgs. Abstract in English. |
“Rate-Compatible QC-LDPC Codes Design Based on EXIT Chart Analysis”, Zaishuang Liu, Kewu Peng, Weilong Lei, Chen Qian and Zhaocheng Wang, Aug. 2012, Published in: 2012 8th International Wireless Communications and Mobile Computing Conference (IWCMC), pp. 921-926. |
“VLSI Decoder Architecture for High Throughput, Variable Block-size and Multi-rate LDPC Codes”, Yang Sun, Marjan Karkooti and Joseph R. Cavellaro, May 2007, reprinted from the Internet at: http://www.ece.rice.edu/˜ys4937/distribute/YangSun_LDPC_ISCAS-07.pdf, pp. 2104-2107. |
Number | Date | Country | |
---|---|---|---|
20170222660 A1 | Aug 2017 | US |