The present technology relates to a data processing device and a data processing method. In particular, the present technology relates to a data processing device and a data processing method that make it possible to ensure good communication quality in a data transmission using LDPC codes.
Some of the information to be published in this specification and drawings, Samsung Electronics Co. to conduct joint development with Sony Corporation, Ltd. (hereinafter, referred to as Samsung) is one that has received the offer from the (explicitly in the drawings).
LDPC (Low Density Parity Check) code has high error correction capabilities, and is widely used in recent years in a transmission system including a digital broadcasting such as DVB (Digital Video Broadcasting)-S.2, DVB-T.2, DVB-C.2 in Europe, and ATSC (Advanced Television Systems Committee) 3.0 in the United States (for example, refer to Non-Patent Document 1).
Recent studies has revealed that as the code length of the LDPC code is prolonged, the LDPC code achieves the performance as close as the Shannon limit similar to the turbo code or the like. Also, the LDPC code has a property that the minimum distance is proportional to the code length. As the advantageous features of the LDPC code, the block error probability characteristic is good, and a so-called error floor phenomenon that is observed in the decoding characteristic of the turbo code or the like is less likely to occur.
Data transmission using an LDPC code, for example, LDPC codes, is a symbol of QPSK (Quadrature Phase Shift Keying) orthogonal modulation such as (digital modulation) (is symbolized), the symbol, the signal points of orthogonal modulation it is mapped to be transmitted.
The data transmission using the LDPC code as described above, it is becoming spread worldwide and is requested to ensure a satisfactory communication quality.
The present technology has been made in view of such circumstances, and, in the data transmission using the LDPC code, is to ensure good communication quality.
The first data processing device/data processing method of the present technology includes a group-wise interleave unit/step of performing group-wise interleave of interleaving in a 360-bit group unit an LDPC code whose code length is 16200 bits and code rate is 10/15, 11/15, 12/15 or 13/15, the (i+1)th bit group from the beginning of the LDPC code of the 16200 bits being as a bit group i, and in the group-wise interleave, a sequence of bit group 0 to 44 of the 16200 bits of the LDPC code being interleaved into the following sequence of the bit group: 15, 25, 9, 27, 5, 38, 13, 10, 19, 16, 28, 1, 36, 0, 11, 17, 32, 35, 7, 26, 14, 21, 6, 4, 23, 22, 3, 18, 20, 24, 30, 12, 37, 2, 40, 8, 33, 29, 31, 34, 41, 42, 43, 44, 39.
The first data processing device/data processing method of the present technology performs group-wise interleave of interleaving in a 360-bit group unit the LDPC code whose code length is 16200 bits and code rate is 10/15, 11/15, 12/15 or 13/15. In the group-wise interleave, the sequence of the 16200 bits of the LDPC code bit group 0 to 44 is interleaved into the following sequence of the bit group: 15, 25, 9, 27, 5, 38, 13, 10, 19, 16, 28, 1, 36, 0, 11, 17, 32, 35, 7, 26, 14, 21, 6, 4, 23, 22, 3, 18, 20, 24, 30, 12, 37, 2, 40, 8, 33, 29, 31, 34, 41, 42, 43, 44, 39.
The second data processing device/data processing method of the present technology includes a group-wise interleave unit of performing group-wise interleave of interleaving in a 360-bit group unit an LDPC code whose code length is 16200 bits and code rate is 10/15, 11/15, 12/15 or 13/15, and a group-wise deinterleave unit/step of returning a sequence of the LDPC code after the group-wise interleave obtained from data transmitted from a transmitting device to the original sequence, the (i+1)th bit group from the beginning of the LDPC code of the 16200 bits being as a bit group i, and in the group-wise interleave, a sequence of bit group 0 to 44 of the 16200 bits of the LDPC code being interleaved into the following sequence of the bit group; 15, 25, 9, 27, 5, 38, 13, 10, 19, 16, 28, 1, 36, 0, 11, 17, 32, 35, 7, 26, 14, 21, 6, 4, 23, 22, 3, 18, 20, 24, 30, 12, 37, 2, 40, 8, 33, 29, 31, 34, 41, 42, 43, 44, 39.
The second data processing device/data processing method of the present technology includes a group-wise interleave unit of performing group-wise interleave of interleaving in a 360-bit group unit an LDPC code whose code length is 16200 bits and code rate is 10/15, 11/15, 12/15 or 13/15, and of returning the sequence of the LDPC code after the group-wise interleave obtained from data transmitted from a transmitting device to the original sequence, the (i+1)th bit group from the beginning of the LDPC code of the 16200 bits being as a bit group i, and in the group-wise interleave, a sequence of bit group 0 to 44 of the 16200 bits of the LDPC code being interleaved into the following sequence of the bit group: 15, 25, 9, 27, 5, 38, 13, 10, 19, 16, 28, 1, 36, 0, 11, 17, 32, 35, 7, 26, 14, 21, 6, 4, 23, 22, 3, 18, 20, 24, 10, 12, 37, 2, 40, 8, 33, 29, 31, 34, 41, 42, 43, 44, 39.
The data processing apparatus may be an independent apparatus or may be an internal block making up one device.
According to the present technology, in the data transmission using the LDPC code, it is possible to ensure good communication quality.
Here, the effects described in are not necessarily limited, it may be any of the effects described in the present disclosure.
Hereinafter, embodiments of the present technology will be described. Before that, an LDPC code will be described.
The LDPC code is a linear code and is not necessarily required to be a binary code; however, it is herein described supposing that this is the binary code.
The greatest characteristic at the LDPC code is that a parity check matrix defining the LDPC code is sparse. Herein, the sparse matrix is the matrix in which the number of elements “I” of the matrix is very small (most of elements are 0).
In the parity check matrix H in
In encoding by the LDPC code (LDPC encoding), a code word (LDPC code) is generated by generation of a generator matrix G based on the parity check matrix H and multiplication of the generator matrix G by a binary information bit, for example.
Specifically, an encoding device, which performs the LDPC encoding, first calculates the generator matrix G satisfying an equation GHT=0 between the same and a transposed matrix HT of the parity check matrix H. Herein, when the generator matrix G is a K×N matrix, the encoding device multiplies a bit column (vector u) of K bits by the generator matrix G to generate a code word c (=uG) configured of N bits. The code word (LDPC code) generated by the encoding device is received on a receiving side through a predetermined communication channel.
Decoding of the LDPC code may be performed by an algorithm suggested by Gallager as probabilistic decoding being a message passing algorithm by belief propagation on a so-called Tanner graph configured of a variable node (also referred to as a message node) and a check node. Hereinafter, the variable node and the check node are appropriately and simply referred to as a node.
A real value (received LLR) representing likelihood of a value to be “0” of an i-th code bit of the LDPC code (one cord word) received on the receiving side by a log likelihood ratio is hereinafter appropriately referred to as a received value u0i. A message output from the check node is set to n. and the message output from the variable node is set to vi.
First, in the decoding of the LDPC code, as shown in
Herein, dv and dc in equations (1) and (2) are parameters indicating the numbers of “1” in a vertical direction (column) and a horizontal direction (row) of the parity check matrix H, which may be optionally selected. For example, it is set that dv=3 and dc=6 in the case of the LDPC code ((3,6) LDPC code) for the parity check matrix H in which the column weight is 3 and the row weight is 6 as shown in
In the variable node operation in equation (1) and the check node operation in equation (2), the message input from an edge (line connecting the variable node and the check node to each other) from which the message is to be output is not a target of the operation, so that a range of the operation is 1 to dv−1 or 1 to dc−1. Also, a table of a function R(v1, v2) represented in equation (3) defined by one output with respect to two inputs v1 and v2 is created in advance and this is continuously (recursively) used as represented in equation (4) for actually performing the check node operation in equation (2).
(Equation 3)
x=2 tan h−1[tan h(v1/2)tan h(v2/2)]=R(v1,v2) (3)
u
j
=R(v2,R(v3, . . . R(vd
At step S12, the variable k is incremented by 1 and the procedure shifts to step S13. At step S13, it is judged whether the variable k is larger than a predetermined number of times of repetitive decoding C. When it is judged that the variable k is not larger than C at step S13, the procedure returns to step S12 and a similar process is hereinafter repeatedly performed.
Also, when it is judged that the variable k is larger than C at step S13, the procedure shifts to step S14 to perform an operation represented in equation (5), so that the message vi as a decoding result to be finally output is obtained to be output and a decoding process of the LDPC code is finished.
Herein, different from the variable node operation in equation (1), the operation in equation (5) is performed using the messages uj from all the edges connected to the variable node.
In the parity check matrix H in
Herein, in
That is to say, when a j-th row i-th column element of the parity check matrix is 1, in
In a sum product algorithm being the decoding method of the LDPC code, the variable node operation and the check node operation are repeatedly performed.
In the variable node, the message vi corresponding to the edge to be calculated is obtained by the variable node operation in equation (1) using the messages u1 and u2 from other edges connected to the variable node and the received value u0i. The message corresponding to another edge is similarly obtained.
Herein, the check node operation in equation (2) may be rewritten as equation (6) using relationship of an equation a×b=exp{ln(|a|)+ln(|b|)}×sign(a)×sign(b). Sign(x) is 1 when x=<0 is satisfied and −1 when x<0 is satisfied.
When a function (φ)(x) is defined by an equation φ(x)=ln(tan h(x/2)) when x=>0 is satisfied, an equation φ−1(x)=2 tan h31 1(e−x) is satisfied so that equation (6) may be deformed to equation (7).
In the chick node, the check node operation in equation (2) is performed according to equation (7).
That is to say, in the check node, the message uj corresponding to the edge to be calculated is obtained by the check node operation in equation (7) using messages v1, v2, v3, v4, and v5 from other edges connected to the check node as illustrated in
The function φ(x) in equation (7) may be represented by an equation φ(x)=ln((ex+1)/(ex−1)) and φ(x)=φ−1(x) when x>0 is satisfied. When the functions φ(x) and φ−1(x) are implemented in hardware, there is a case in which they are implemented using LUT (look up table), and the same LUT is used for both of them.
<Configuration Example of Transmission System to which the Present Technology is Applied>
In
The transmitting device 11 transmits (broadcasts) (transmits) a program of television broadcasting. That is to say, the transmitting device 11 encodes target data to be transmitted such as image data and audio data as the program, for example, into an LDPC code and transmits the same through a communication channel 13 such as a satellite circuit, a terrestrial wave, and a cable (wire circuit).
The receiving device 12 receives the LDPC code transmitted from the transmitting device 11 through the communication channel 13 and decodes the same to the target data to output.
Herein, it is known that the LDPC code used in the transmission system in
However, a burst error and erasure might occur in the communication channel 13 such us the terrestrial wave. For example, especially when the communication channel 13 is a terrestrial wave, in an OFDM (orthogonal frequency division multiplexing) system, there is a case in which power of a specific symbol reaches 0 (erasure) according to delay of an echo (a path other than a main path) in a multipath environment in which a D/U (desired to undesired ratio) is 0 dB (power of undesired (=echo) is equal to power of desired (=main path)).
There is a case in which the power of all the symbols of the OFDM at a specific time reaches 0 (erasure) by a Doppler frequency when the D/U is 0 dB also in a flutter (communication channel in which a Doppler frequency-shifted echo whose delay is 0 is added).
Further, the burst error might occur due to a wiring status from a receiver (not shown) such as an antenna, which receives a signal from the transmitting device 11, to the receiving device 12 and instability of a power supply of the receiving device 12 on a side of the receiving device 12.
On the other hand, in decoding of the LDPC code, a variable node operation in equation (1) including addition of (a received value u0i of) a code bit of the LDPC code is performed as illustrated above in
In the decoding of the LDPC code, a check node operation in equation (7) is performed in the check node using the message obtained in the variable node connected to the check node, so that decoding performance is deteriorated when the number of check nodes, in which (the code bits of the LDPC code corresponding to) a plurality of variable nodes connected thereto have the error (including the erasure) at the same time, increases.
That is to say, when the erasure occurs in two or more of the variable nodes connected to the check node at the same time, the check node returns the message indicating that probability that the value is 0 and the probability that the value is 1 are equal to all the variable nodes, for example. In this case, the check node, which returns the message of the equal probability, does not contribute to a single decoding process (one set of the variable node operation and the check node operation), and as a result, this requires a large number of repetitions of the decoding process, so that the decoding performance is deteriorated and further, power consumption of the receiving device 12, which decodes the LDPC code, increases.
Therefore, the transmission system in
In the transmitting device 11, one or more input streams as the target data are supplied to a mode adaptation/multiplexer 111.
The mode adaptation/multiplexer 111 selects a mode, multiplexes the one or more input streams supplied thereto, and supplies the data obtained as a result to a padder 112.
The padder 112 performs necessary zero padding (null insertion) to the data from the mode adaptation/multiplexer 111 and supplies the data obtained as a result to a BB scrambler 113.
The BB scrambler 113 applies BB scramble (Base-Band Scrambling) to the data from the padder 112 and supplies the data obtained as a result to a BCH encoder 114.
The BCH encoder 114 performs BCH encoding of the data from the BB scrambler 113 and supplies the data obtained as a result to an LDPC encoder 115 as LDPC target data being a target of LDPC encoding.
The LDPC encoder 115 performs the LDPC encoding of the LDPC target data from the BCH encoder 114 according to a parity check matrix in which a parity matrix being a part corresponding to a parity bit of the LDPC code has a stepwise structure and outputs the LDPC code in which an information bit is the LDPC target data.
That is to say, the LDPC encoder 115 performs the LDPC encoding to encode the LDPC target data into the LDPC code (corresponding to the parity check matrix) such as the LDPC code specified in a predetermined standard such as a DVB-S.2 standard, a DVB-T.2 standard and a DVB-C.2 standard or the LDPC code expected to be specified by ATSC3.0 (corresponding to the parity check matrix), for example, and outputs the LDPC code obtained as a result.
In the LDPC code specified in the DVB-T.2 standard or the LDPC code expected to be specified by ATSC3.0 is an IRA (irregular repeat-accumulate) code and the parity matrix in the parity check matrix of the LDPC code has the stepwise structure. The parity matrix and the stepwise structure are described later. The IRA code is described in “Irregular Repeat-Accumulate Codes,” H. Jin, A. Khandekar, and R. J. McEliece, in Proceedings of 2nd International Symposium on Turbo Codes and Related Topics, pp. 1-8, September 2000, for example.
The LDPC code output by the LDPC encoder 115 is supplied to a bit interleaver 116.
The bit interleaver 116 performs bit interleave to be described later of the LDPC code from the LDPC encoder 115 and supplies the LDPC code after the bit interleave to a mapper 117.
The mapper 117 maps the LDPC code from the bit interleaver 116 onto a signal point indicating one symbol of orthogonal modulation in units of one or more code bits of the LDPC code (symbol unit) to perform the orthogonal modulation (multilevel modulation).
That is to say, the mapper 117 maps the LDPC code from the bit interleaver 116 onto the signal point defined by a modulation scheme for performing the orthogonal modulation of the LDPC code on an IQ plane (IQ constellation) defined by an I axis representing an I component in phase with a carrier wave and a Q axis representing a Q component orthogonal to the carrier wave and performs the orthogonal modulation.
If the number of signal points prescribed by orthogonal modulation of a modulation scheme which is performed by the mapper 117 is 2m, the mapper 117 maps the LDPC code from the bit interleaver 116 in a symbol unit onto the signal point indicating the symbol of the 2m signal points as the m code bit of the LDPC code for a symbol (I symbol).
Herein, the modulation scheme of the orthogonal modulation performed by the mapper 117 includes the modulation scheme including the modulation scheme specified in the DVB-T.2 standard, for example, the modulation scheme expected to be specified by ATSC3.0, and other modulation schemes, that is to say, BPSK (Binary Phase Shift Keying), QPSK (quadrature phase shift keying), 8PSK (Phase-Shift Keying). 16APSK (Amplitude Phase-Shift Keying), 32APSK, 16QAM (quadrature amplitude modulation), 16QAM, 64QAM, 256QAM, 1024QAM 4086QAM, 4PAM (Pulse Amplitude Modulation) and the like, for example. The modulation scheme with which the orthogonal modulation is performed by the mapper 117 is set in advance according to operation of an operator of the transmitting device 11, for example.
The data (symbol mapped onto the signal point) obtained by the process by the mapper 117 is supplied to a time interleaver 118.
The time interleaver 118 performs time interleave (interleave in a time direction) in a symbol unit of the data from the mapper 117 and supplies the data obtained as a result to a SISO/MISO (Single Input Single Output/Multiple Input Single Output) encoder 119.
The SISO/MISO encoder 119 applies time-space encoding to the data from the time interleaver 118 to supply to a frequency interleaver 120.
The frequency interleaver 120 performs frequency interleave (interleave in a frequency direction) for the unit of the data from the SISO/MISO encoder 119 in a symbol unit, and supplies it to a frame builder & resource allocation 131.
On the other hand, control data for transmission control (signaling) such as Base Band Signaling, BB Header and the like is supplied to the BCH encoder 121, for example.
The BCH encoder 121 performs the BCH encoding of the control data supplied thereto in the same manner as the BCH encoder 114 and supplies the data obtained as a result to an LDPC encoder 122.
The LDPC encoder 122 performs the LDPC encoding of the data from the BCH encoder 121 as the LDPC target data in the same manner as the LDPC encoder 115 and supplies the LDPC code obtained as a result to a mapper 123.
The mapper 123 maps the LDPC code from the LDPC encoder 122 onto the signal point indicating one symbol of the orthogonal modulation in units of one or more code bits of the LDPC code (symbol unit) to perform the orthogonal modulation and supplies the data obtained as a result to a frequency interleaver 124 in the same manner as the mapper 117.
The frequency interleaver 124 performs the frequency interleave of the data from the mapper 123 in a symbol unit to supply to the frame builder & resource allocation 131 in the same manner as the frequency interleaver 120.
The frame builder & resource allocation 131 inserts a pilot symbol into a required position of the data (symbol) from the frequency interleavers 120 and 124 and constitutes a frame configured of a predetermined number of symbols (for example, a PL (Physical layer) frame, a T2 frame, a C2 frame and the like) from the data (symbol) obtained as a result to supply to an OFDM generation 132.
The OFDM generation 132 generates an OFDM signal corresponding to the frame from the frame from the frame builder & resource allocation 131 and transmits the same through the communication channel 13 (
The transmitting device 11 may be configured without including some of the blocks shown in
The bit interleaver 116 has a function to interleave the data, and is configured of a parity interleaver 23, a group-wise interleaver 24, and a block interleaver 25.
The parity interleaver 23 performs parity interleave to interleave the parity bit of the LDPC code from the LDPC encoder 115 to a position of another parity bit and supplies the LDPC code after the parity interleave to the group-wise interleaver 24.
The group-wise interleaver 24 performs group-wise interleave of the LDPC code from the parity interleaver 23 and supplies the LDPC code after the group-wise interleave to the block interleaver 25.
Here, in the group-wise interleave, the LDPC code for one code is divided into a 360-bit unit equal to the number of columns P being the unit of the cyclic structure as described later from the beginning. One division, i.e., 360-bit, is considered as a bit group. The LDPC code from the parity interleaver 23 is interleaved in a bit group unit.
When the group-wise interleave is performed, the bit error rate can be improved as compared with the case that no group-wise interleave is performed. As a result, in the data transmission, it is possible to ensure good communication quality.
The block interleaver 25 performs the block interleave for demultiplexing the LDPC code from the group-wise interleaver 24, symbolizes the LDPC code for one code into the m bit symbol in a mapping unit, and supplies it to the mapper 117 (
Here, there is a storage region where columns for storing a predetermined number of bits in a column (vertical) direction are arranged in equal numbers to the bit numbers m of the symbol in a row (horizontal) direction. In the block interleave, the LDPC code from the group-wise interlever 24 is written in the column direction and read in the row direction, thereby symbolizing the LDPC code for one code into the m bit symbol.
The parity check matrix H has an LDGM (low-density generation matrix) structure and this may be represented by an equation H=[HA|HT] in which a left element is an element of an information matrix HA and a right element is an element of a parity matrix HT) by the information matrix HA of a part corresponding to the information bit and the parity matrix HT corresponding to the parity bit out of the code bits of the LDPC code.
Herein, the number of information bits and the number of parity bits out of the code bits of one LDPC code (one code word) are referred to as an information length K and a parity length M, respectively, and the number of code bits of one LDPC code is referred to as a code length K (=K+M).
The information length K and the parity length M of the LDPC code of a certain code length N are determined according to the code rate. The parity check matrix H is an M×N (row×column) matrix. The information matrix HA is an M×K matrix and the parity matrix HT is an M×M matrix.
The parity matrix HT of the parity check matrix H used for the LDPC encoding by the LDPC encoder 115 is similar to the parity matrix HT of the parity check matrix H of the LDPC code specified in the DVB-T.2 standard.
The purity matrix HT of the parity check matrix H of the LDPC code specified in the DVB-T.2 standard has a lower bidiagonal matrix in which elements of 1 are arranged in a so-called stepwise manner as shown in
As described above, the LDPC code of the parity check matrix H in which the parity matrix HT has the stepwise structure may be easily generated using the parity check matrix H.
That is to say, the LDPC code (one code word) is represented by a row vector c and a column vector obtained by transposing the row vector is represented as cT. A part of the information bit of the row vector c, which is the LDPC code, is represented by a row vector A and a part of the parity bit is represented by a row vector T.
In this case, the row vector c may be represented by an equation c=[A|T] (row vector in which a left element is an element of the row vector A and a right element is an element of the row vector T) by the row vector A as the information bit and the row vector T as the parity bit.
The parity check matrix H and the row vector c=[A|T] as the LDPC code are required to satisfy an equation HcT=0 and it is possible to sequentially obtain (in order) the row vector T to the parity bit configuring the row vector c=[A|T] satisfying such equation HcT=0 by setting the element of each row to 0 in order from the element of a first row of the column vector HcT in the equation HcT=0 when the parity matrix HT of the parity check matrix H=[HA|HT] bits the stepwise structure illustrated in
The column weight is X for first to KX-th columns, the column weight is 3 for next K3 columns, the column weight is 2 for next M−1 columns, and the column weight is 1 for a last column in the parity check matrix H of the LDPC code specified in the DVB-T.2 standard.
Herein, KX+K3+M−1+1 equals to the code length N.
The LDPC codes whose code lengths N are 64800 bits and 16200 bits are specified in the DVB-T.2 standard.
For the LDPC code whose code length N is 64800 bits, 11 code rates (nominal rates) 1/4, 1/3, 2/5, 1/2, 3/5, 2/3, 3/4, 4/5, 5/6, 8/9, and 9/10 are specified, and for the LDPC code whose code length N is 16200 bits, 10 code rates 1/4, 1/3, 2/5, 1/2, 3/5, 2/3, 3/4, 4/5, 5/6, and 8/9 are specified.
The code length N of 64800 bits is hereinafter also referred to as 64k bits and the code length of 16200 bits is also referred to as 16k bits.
As for the LDPC code, it is known that a bit error rate of the code bit corresponding to the column whose column weight is larger of the parity check matrix H is lower.
In the parity check matrix H specified in the DVB-T.2 standard illustrated in
Referring to
The check node returns the message indicating that the probability that the value is 0 and the probability that the value is 1 are equal to all the variable nodes connected to the check node when the error such as the erasure occurs in a plurality (for example, two) of (code bits corresponding to the) variable nodes connected to the check node of the same time as illustrated in
The LDPC code specified in the DVB-S.2 standard output by the LDPC encoder 115 in
In the parity matrix HT having the stepwise structure, the elements of 1 are adjacent to each other in each row (except the fiat row). Therefore, in the Tanner graph of the parity matrix HT, two adjacent variable nodes corresponding to the columns of the two adjacent elements whose value is 1 of the parity matrix HT are connected to the same check node.
Therefore, when the error occurs in the parity bits corresponding to the above-described adjacent two variable nodes at the same time due to the burst error, the erasure and the like, the check node connected to the two variable nodes (the variable nodes, which obtain the message using the parity bits) corresponding to the two parity bits in which the error occurs returns the message indicating that the probability that the value is 0 and the probability that the value is 1 are equal to the variable nodes connected to the check node, whereby the decoding performance is deteriorated. When a burst length (the number of parity bits in which the error is successively occurs) increases, the number of check nodes, which return the message of the equal probability, increases and the decoding performance is further deteriorated.
Then, the parity interleaver 23 (
Herein, the information matrix HA of the parity check matrix H corresponding to the LDPC code output by the LDPC encoder 115 has a cyclic structure, similar to the information matrix of the parity check matrix H corresponding to the LDPC code specified in the DVB-T.2 standard.
The term “cyclic structure” is intended to mean a structure in which a certain column is identical to a column obtained by a cyclic shift of another column and includes a structure in which a position of 1 in each row of P columns is set to a position obtained by the cyclic shirt of a first column of the P columns in the column direction by a value proportional to a value q obtained by dividing the parity length M for each P columns, for example. Hereinafter, P in the cyclic structure is appropriately referred to as the number of columns being a unit of the cyclic structure.
There are two types of LDPC codes whose code lengths N are 64800 bits and 16200 bits as the LDPC code specified in the DVB-T.2 standard as illustrated in
The parity length M is set to a value other than a prime number represented by an equation M=q×P=q×360 using the value q different according to the code rate. Therefore, as the number of columns P being the unit of the cyclic structure, the value q also is another submultiple other than 1 and M out of the submultiples of the parity length M and this may be obtained by dividing the parity length M by the number of columns P being the unit of the cyclic structure (a product of P and q being the submultiples of the parity length M is the parity length M).
When the information length is K, an integer not smaller than 0 and smaller than P is x, and an integer not smaller than 0 and smaller than q is y, the parity interleaver 23 interleaves a K+qx+y+1-th code bit out of the code bits of the N-bit LDPC code to position of K+Py+x+1-th code bit as the parity interleave as described above.
Both the K+qx+y+1-th code bit and the K+Py+x+1-th code bit are the cede bits after a K+1-th code bit, so that they are the parity bits, therefore, the position of the parity bit of the LDPC code is moved by the purity interleave.
According to such parity interleave, (the parity bits corresponding to) the variable nodes connected to the same check node are apart from each other by the number of columns P being the unit of the cyclic structure, that is to say, herein 360 bits, so that a situation in which the error occurs in a plurality of variable nodes connected to the same check node at the same time may be avoided in a case in which the burst length is shorter than 360 bits, and as a result, the resistance to burst error may be improved.
The LDPC code after the parity interleave to interleave the K+qx+y+1-th code bit to the position of the K+Py+x+1-th code bit is identical to the LDPC code of the parity check matrix obtained by performing column permutation to change the K+qx+y+1-th column of the original parity check matrix H to the K+qx+x+1-th column (hereinafter, also referred to as a conversion parity check matrix).
Also, a quasi-cyclic structure in units of P columns (360 columns in
Herein, the term “quasi-cyclic structure” is intended to mean a structure in which a portion except a part has the cyclic structure.
In the conversion parity check matrix obtained by applying the column permutation corresponding to the parity interleave to the parity check matrix of the LDPC code specified in the DVB-T.2 standard, one element 1 is lacking (there is an element 0) in a portion of 360 rows×360 columns in a right corner of the conversion parity check matrix (a shift matrix to be described later), so that this does not have the (complete) cyclic structure and has the so-called quasi-cyclic structure in this point.
The conversion parity check matrix of the partly check matrix of the LDPC code output by the LDPC encoder 115 has a quasi-cyclic structure, similar to the conversion parity check matrix of the parity check matrix H of the LDPC code specified in the DVB-T.2 standard.
The conversion parity check matrix in
The LDPC encoder 115 encodes the LDPC target data into the LDPC code at step S101 after waiting for supply of the LDPC target data from the BCH encoder 114 and supplies the LDPC code to the bit interleaver 116, then the process shifts to step S102.
The bit interleaver 116 performs the bit interleave of the LDPC code from the LDPC encoder 115 and supplies the symbol obtained by the bit interleave to the mapper 117 at step S102, then the process shifts to step S103.
That is to say, at step S102, in the bit interleaver 116 (
The group-wise interleaver 24 performs the group-wise interleave of the LDPC code from the parity interleaver 23 to supply to the block interleaver 25.
The block interleaver 25 performs the block interleave of the LDPC code after the group-wise interleave by the group-wise interleaver 24 and supplies the m bit symbol obtained as a result to the mapper 117.
The mapper 117 maps the symbol from the block interleaver 25 onto any of the 2m signal points defined by the modulation scheme of the orthogonal modulation performed by the mapper 117 to perform the orthogonal modulation and supplies the data obtained as a result to the time interleaver 118 at step S103.
As described above, it is possible to improve the error rate in a case in which a plurality of code bits of the LDPC code is transmitted as one symbol by performing the parity interleave and the group-wise interleave.
Herein, the parity interleaver 23, which is a block to perform the parity interleave, and the group-wise interleaver 24, which is a block to perform the group-wise interleave, are separately formed in
That is to say, the parity interleave and the group-wise interleave may be performed by the writing and the reading of the code bit to and from the memory and may be represented by a matrix to convert the address at which the code bit is written (write address) to the address at which the code bit is read (read address).
Therefore, by obtaining the matrix obtained by multiplying the matrix representing the parity interleave by the matrix representing the group-wise interleave, it is possible to obtain a result of performing the parity interleave and performing the group-wise interleave of the LDPC code after the parity interleave by converting the code bit by the matrix.
It is also possible to integrally form the block interleaver 25 in addition to the parity interleaver 23 and the group-wise interleaver 24.
That is to say, the block interleave performed by the block interleaver 25 may also be represented by the matrix to convert the write address of the memory, which stores the LDPC code, to the read address.
Therefore, by obtaining the matrix obtained by multiplying the matrix representing the parity interleave, the matrix representing the group-wise interleave, and the matrix representing the block interleave together, it is possible to collectively perform the parity interleave, the group-wise interleave, and the block interleave by the matrix.
The LDPC encoder 122 in
As illustrated in
As for the LDPC code whose code length N is 64800 bits, 11 code rates 1/4, 1/3, 2/5, 1/2, 3/5, 2/3, 3/4, 4/5, 5/6, 8/9, and 9/10 are specified, and as for the LDPC code whose code length N is 16200 bits, 10 code rates 1/4, 1/3, 2/5, 1/2, 3/5, 2/3, 3/4, 4/5, 5/6 and 8/9 are specified (refer to
The LDPC encoder 115 may perform the encoding (error correction encoding) by such LDPC code of each code rate whose code lengths N are 64800 bits or 16200 bits according to the parity check matrix H prepared for each code length N and each code rate, for example.
The LDPC encoder 115 is configured of an encoding processor 601 and a storage unit 602.
The encoding processor 601 is configured of a code rate set unit 611, an initial value table read unit 612, a parity check matrix generation unit 613, an information bit read unit 614, an encoding parity operation unit 615, and a controller 616, and this performs the LDPC encoding of the LDPC target data supplied to the LDPC encoder 115 and supplies the LDPC code obtained as a result to the bit interleaver 116 (
That is to say, the code rate set unit 611 sets the code length N and the code rate of the LDPC code according to the operation of the operator and the like, for example.
The initial value table read unit 612 reads a parity check matrix initial value table to be described later corresponding to the code length N and the code rate set by the code rate set unit 611 from the storage unit 602.
The parity check matrix generation unit 613 generates the parity check matrix H by arranging the element 1 of the information matrix HA corresponding to the information length K (=code length N−parity length M) according to the code length N and the code rate set by the code rate set unit 611 with a period of 360 columns (the number of columns P being the unit of the cyclic structure) in the column direction based on the parity check matrix initial value table read by the initial value table read unit 612 and stores the same in the storage unit 602.
The information bit read unit 614 reads (extracts) the information bit as many as the information length K from the LDPC target data supplied to the LDPC encoder 115.
The encoding parity operation unit 615 reads the parity check matrix H generated by the parity check matrix generation unit 613 from the storage unit 602 and calculates the parity bit for the information bit read by the information bit read unit 614 based on a predetermined equation using the parity check matrix H, thereby generating the code word (LDPC code).
The controller 616 controls each block configuring the encoding processor 601.
A plurality of parity check matrix initial value tables and the like corresponding to a plurality of code rates and the like illustrated in
At step S201, the code rate set unit 611 determines (sets) the code length N and the code rate r with which the LDPC encoding is performed.
At step S202, the initial value table read unit 612 reads the parity check matrix initial value table determined in advance corresponding to the code length N and the code rate r determined by the code rate set unit 611 from the storage unit 602.
At step S203, the parity check matrix generation unit 613 obtains (generates) the parity check matrix H of the LDPC code whose code length N and the code rate r determined by the code rate set unit 611 using the parity check matrix initial value table read by the initial value table read unit 612 from the storage unit 602 and supplies the same to the storage unit 602 to store.
At step S204, the information bit read unit 614 reads the information bits of the information length K (=N×r) corresponding to the code length N and the code rate r determined by the code rate set unit 611 from the LDPC target data supplied to the LDPC encoder 115 and reads the parity check matrix H obtained by the parity check matrix generation unit 613 from the storage unit 602 to supply to the encoding parity operation unit 615.
At step S205, the encoding parity operation unit 615 sequentially calculates the parity bit of the code word c satisfying equation (8) using the information bit from the information bit read unit 614 and the parity check matrix H.
HcT=0 (8)
In equation (8), c represents the row vector as the code word (LDPC code) and cT represents transposition of the row vector c.
Herein, as described above, when the part of the information bit and the part of the parity bit of the row vector c as the LDPC code (one code word) are represented by the row vector A and the low vector T, respectively, the row vector c may be represented by the equation c=[A|T] by the row vector A as the information bit and the row vector T as the parity bit.
The parity check matrix H and the row vector c=[A|T] as the LDPC code are required to satisfy the equation HcT=0 and it is possible to sequentially obtain the row vector T as the parity bit configuring the row vector c=[A|T] satisfying such equation HcT=0 by setting the element of each row to 0 in order from the element of the first row of the column vector HcT in the equation HcT=0 when the parity matrix HT of the parity check matrix H=[HA|HT] has the stepwise structure illustrated in
When the encoding parity operation unit 615 obtains the parity bit T for the information bit A from the information bit read unit, this outputs the code word c=[A|T] represented by the information bit A and the parity bit T as a result of the LDPC encoding of the information bit A.
Thereafter, at step S206, the controller 616 judges whether to finish the LDPC encoding. At step S206, when it is judged that the LDPC encoding is not finished, that is to say, when there still is the LDPC target data to be LDPC encoded, for example, the process returns to step S201 (or step S204) and the processes at steps S201 (or step S204) to S206 are hereinafter repeated.
When it is judged that the LDPC encoding is finished at step S206, that is to say, there is no LDPC target data to be LDPC encoded, for example, the LDPC encoder 115 finishes the process.
In this manner, the parity check matrix initial value table corresponding to each code length N and each code rate r is prepared, and the LDPC encoder 115 performs the LDPC encoding with a predetermined code length N and a predetermined code rate r using the parity check matrix H generated from the parity check matrix initial value table corresponding to the predetermined code length N and the predetermined code rate r.
The parity check matrix initial value table is the table indicating the position of the element 1 of the information matrix HA (
That is to say,
The parity check matrix generation unit 613 (
In other words, the parity check matrix initial value table in
The parity check matrix initial value table is the table indicating the position of the element 1 of the information matrix HA (
Herein, the parity matrix HT (
The number of rows k+1 of the parity check matrix initial value table differs according to the information length K.
The information length K and the number of rows k+1 of the parity check matrix initial value table satisfy relationship in equation (9).
K=(k+1)×360 (9)
Herein, 360 in equation (9) is the number of columns P being the unit of the cyclic structure illustrated in
In the parity check matrix initial value table in
Therefore, the column weights of the parity check matrix H obtained from the parity check matrix initial value table in
The first row of the parity check matrix initial value table in
Also, the second row of the parity check matrix initial value table in
As described above, the parity check matrix initial value table indicates the position of the element 1 of the information matrix HA of the parity check matrix H for each 360 columns.
The column other than the 1+360×(i−1)-th column of the parity check matrix H, that is to say, each column from a 2+360×(i−1)-th column to a 360×i-th column is obtained by periodically performing the cyclic shift to the element 1 of the 1+360×(i−1)-th column determined by the parity check matrix initial value table downward (in a direction toward a lower part of the column) according to the parity length M to arrange.
That is to say, the 2+360×(i−1)-th column is obtained by the cyclic shift of the 1+360×(i−1)-th column downward by M/360(=q) and a next 3+360×(i−1)-th column is obtained by the cyclic shift of the 1+360×(i−1)-th column downward by 2×M/360(=2×q) (the cyclic shift of the 2+360 ×(i−1)-th column downward by M/360(=q)), for example.
Herein, if an i-th row (i-th row from the top) j-th column (j-th column from left) value of the parity check matrix initial value table is represented as hi,j and the row number of a j-th element 1 of a w-th column of the parity check matrix H is represented as Hw-j, a row number Hw-j of the element 1 of the w-th column being the column other than the 1+360×(i−1)-th column of the parity check matrix H may be obtained by equation (10).
H
w-j=mod{Hi,j+mod((w−1),P)×q,M) (10)
Herein, mod (x, y) represents a remainder obtained when x is divided by y.
Also, P represents the above-described number of columns being the unit of the cyclic structure, which is set to 360 as described above in the DVB-S.2 standard, the DVB-T.2 standard and the DVB-C.2 standard, for example. Further, q represents a value M/360 obtained by dividing the parity length M by the number of columns P (=360) being the unit of the cyclic structure.
The parity check matrix generation unit 613 (
Further, the parity check matrix generation unit 613 (
At present, the standard for terrestrial digital television broadcasting which is called as ATSC3.0 is planned.
A planned LDPC code (hereinafter also referred to as a “new LDPC code”) such as ATSC3.0 and other data broadcasting will be described.
As for the new LDPC code, the parity matrix HT of the parity check matrix H has the stepwise structure (
Further, as for the new LDPC code, as is the case with the LDPC code specified in DVB-T.2, the information matrix HA of the parity check matrix H has the cyclic structure and the number of columns P being the unit of the cyclic structure is set to 360.
The LDPC encoder 115 (
In this case, the parity check matrix initial value table is stored in the storage unit 602 of the LDPC encoder 115 (
(The parity check matrix initial value tables of the parity check matrices H of) the second new LDPC codes shown in
The first new LDPC codes and the first other new LDPC codes are high-performance LDPC codes.
Herein, the high-performance LDPC code is obtained from an appropriate parity check matrix H.
The term the “appropriate parity check matrix H” is intended to mean the parity check matrix, which satisfies a predetermined condition to make the BER (and FER) lower when the LDPC code obtained from the parity check matrix H is transmitted with low Es/No or Eb/No (signal power to noise power ratio per bit).
The appropriate parity check matrix H may be obtained by the simulation of the measurement of the BER at the time when the LDPC code obtained from the various parity check matrices satisfying the predetermined condition is transmitted with the low Es/No, for example.
The predetermined condition, which the appropriate parity check matrix H should satisfy, includes an excellent analysis result obtained by an analyzing method of performance of the code referred to as density evolution, absence of a loop of the elements of 1 referred to as cycle-4 and the like, for example.
Herein, it is known that the decoding performance of the LDPC code is deteriorated when the elements of 1 close up as the cycle-4 in the information matrix HA, so that the absence of the cycle-4 is required as the predetermined condition, which the appropriate parity check matrix H should satisfy.
The predetermined condition, which the appropriate parity check matrix H should satisfy, may be appropriately determined from a viewpoint of improvement in the decoding performance of the LDPC code, facilitation (simplification) of the decoding process of the LDPC code and the like.
The density evolution is the analyzing method of the code, which calculates an expected value of the error probability for an entire LDPC code (ensemble) whose code length N is ∞ characterized by a degree sequence to be described later.
For example, when a variance value of noise is set to be larger from 0 on the AWGN channel, the expected value of the error probability of a certain ensemble, which is initially 0, is no longer 0 when the variance value of the noise becomes a certain threshold or larger.
According to the density evolution, it is possible to determine whether performance of the ensemble (appropriateness of the parity check matrix) is excellent by comparing the threshold of the variance value of the noise (hereinafter, also referred to as a performance threshold) at which the expected value of the error probability is no longer 0.
It is possible to predict rough performance of a specific LDPC code by determining the ensemble to which the LDPC code belongs and performing the density evolution to the ensemble.
Therefore, when a high-performance ensemble is found, the high-performance LDPC code may be found from the LDPC codes belonging to the ensemble.
Herein, the above-described degree sequence indicates a ratio of the variable node and the check node having the weight of each value to the code length N of the LDPC code.
For example, a regular (3, 6) LDPC code whose code rate is 1/2 belongs to the ensemble characterized by the degree sequence in which the weight (column weight) of all the variable nodes is 3 and the weight (row weight) of all the check nodes is 6.
In the Tanner graph in
Three edges, the number of which is equal to the column weight, are connected to each variable node, so that there are a total of 3N edges connected to the N variable nodes.
Also, six edges the number of which is equal to the row weight, are connected to each check node, so that there are a total of 3N edges connected to the N/2 check nodes.
Further, there is one interleaver in the Tanner graph in
The interleaver randomly rearranges the 3N edges connected to the N variable nodes and connects the rearranged edges to any of the 3N edges connected to the N/2 check nodes.
there are (3N)!(=(3N)×(3N−1)×. . . ×1) rearranging patterns of rearranging the 3N edges connected to the N variable nodes by the interleaver. Therefore, the ensemble characterized by the degree sequence in which the weight of all the variable nodes is 3 and the weight of all the check nodes is 6 is a set of (3N)! LDPC codes.
In the simulation for obtaining the high-performance LDPC code (appropriate parity check matrix), a multi-edge type ensemble is used in the density evolution.
In the multi-edge type, the interleaver through which the edge connected to the variable node and the edge connected to the check node pass is divided into a multi-edge one, so that the ensemble is more strictly characterized.
In the Tanner graph in
In the Tanner graph in
Further, in the Tanner graph in
Herein, the density evolution and implementation thereof are described in “On the Design of Low-Density Parity-Check Codes within 0.0045 dB of the Shannon Limit”, S. Y. Chung. G. D. Forney, T. J. Richardson, and R. Urbanke, IEEE Communications Leggers, VOL. 5, NO. 2, February 2001, for example.
In the simulation for obtaining (the parity check matrix initial value table of) the first new LDPC codes and the first other new LDPC code, the ensemble in which the performance threshold being Eb/No (signal power to noise power ratio per bit) at which the BER starts to decrease (to be lower) is a predetermined value or smaller is found by multi-edge type density evolution and the LDPC code to decrease the BER is selected as the high-performance LDPC code out of the LDPC codes belonging to the ensemble.
The parity check matrix initial value tables of the above-described first new LDPC codes and first other new LDPC codes are determined by the above simulation.
Accordingly, by the first new LDPC codes and the first other new LDPC codes obtained from the parity check matrix initial value tables, it is possible to ensure a good communication quality in the data transmission.
Here, the minimum cycle length (girth) means a minimum value of a length of a loop (loop length) configured of the elements of 1 in the parity check matrix H.
The parity check matrices H of the first new LDPC codes of (64k, 7/15), (64k, 9/15), (64k, 11/15) and (64k, 13/15) have no cycle-4 (the loop length of four, a loop of the elements of 1).
The performance threshold of the first new LDPC code of (64k, 7/15) is −0.093751, the performance threshold of the first new LDPC code of (64k, 9/15) is 1.658523, the performance threshold of the first new LDPC code of (64k, 11/15) is 3.351930 and the performance threshold of the first new LDPC code of (64k, 13/15) is 5.301749.
The column weight is X1 for first to KX1-th columns of the parity check matrices H of the first new LDPC codes of (64k, 7/15), (64k, 9/15), (64k, 11/15) and (64k, 13/15), the column weight is X2 for next KY2 columns, the column weight is Y1 for next KY1 columns, the column weight is Y2 for next KY2 columns, the column weight is 2 for next M−1 columns, and the column weight is 1 for a last column, respectively.
Herein, KX1+KX2+KY1+KY2+M−1+1 is equal to the code length N=64800 bits of the first new LDPC codes of (64k, 7/15), (64k, 9/15), (64k, 11/15) and (64k, 13/15).
As for the parity check matrices H of the first new LDPC codes of (64k, 7/15), (64k, 9/15), (64k, 11/15) and (64k, 13/15), as is the case with the parity check matrix illustrated in
In the simulation, the AWGN channel is supposed, and 50 times is adopted as the number of times of repetitive decoding C for decoding the LDPC code.
In
According to
The parity check matrices H or the first new LDPC codes of (16k, 6/15), (16k, 8/15), (16k, 10/15) and (16k, 12/15) have no cycle-4.
The performance threshold of the first new LDPC code of (16k, 6/15) is 0.01, the performance threshold of the first new LDPC code of (16k, 8/15) is 0.805765, the performance threshold of the first new LDPC code of (16k, 10/15) is 2.471011 and the performance threshold of the first new LDPC code of (16k, 12/15) is 4.269922.
The column weight is X1 for first to KX1-th columns of the parity check matrices H of the first new LDPC codes of (16k, 6/15), (16k, 8/15), (16k, 10/15) and (16k, 12/15), the column weight is X2 for next KY2 columns, the column weight is Y1 for next KY1 columns, the column weight is Y2 for next KY2 columns, the column weight is 2 for next M−1 columns and the column weight is 1 for a last column, respectively.
Herein, KX1+KX2+KY1+KY2+M−1+1 is equal to the code length N=16200 bits of the first new LDPC codes of (16k, 6/15), (16k, 8/15), (16k, 10/15) and (16k, 12/15).
As for the parity check matrices H of the first new LDPC codes of (16k, 6/15), (16k, 8/15), (16k, 10/15) and (16k, 12/15), as is the case with the parity check matrix illustrated in
In the simulation, the AWGN channel is supposed as the communication channel 13 (
In
According to
Accordingly, it can confirm that a good communication quality is ensured in the data transmission using the first new LDPC codes of (16k, 6/15), (16k, 8/15), (16k, 10/15) and (16k, 12/15).
The parity check matrix H of the other first new LDPC code of (16k, 10/15) has no cycle-4.
The performance threshold of the first other new LDPC code of (16k, 10/15) is 1.35.
The column weight is X for first to KX1-th columns of the parity check matrix H of the first other new LDPC code of (16k, 10/15), the column weight is Y1 for next KY1 columns, the column weight is Y2 for next KY2 columns, the column weight is 2 for next M−1 columns, and the column weight is 1 for a last column, respectively.
Herein, KX1+KX2+KY1+KY2+M−1+1 is equal to the code length N=16200 bits of the first other new LDPC code of (16k, 10/15).
As for the parity check matrix H of the first other new LDPC code of (16k, 10/15), as is the case with the parity check matrix illustrated in
In the simulation, the AWGN channel is supposed as the communication channel 13 (
The parity check matrices H of the first other new LDPC code of (16k, 12/15) has no cycle-4.
The performance threshold of the first other new LDPC code of (16k, 12/15) is 4.237556.
The column weight is X1 for first to KX1-th columns of the parity check matrix H of the first other new LDPC code of (16k, 12/15), the column weight is X2 for next KY2 columns, the column weight is Y1 for next KY1 columns, the column weight is Y2 for next KY2 columns, the column weight is 2 for next M−1 columns, and the column weight is 1 for a last column, respectively.
Herein, KX1+KX2+KY1+KY2+M−1+1 is equal to the cock length N=16200 bits of the first other new LDPC code of (16k, 10/15).
As for the parity check matrix H of the first otter new LDPC code of (16k, 12/15), as is the case with the parity check matrix illustrated in
In the simulation, the AWGN channel is supposed as the communication channel 13 (
In
According to
The column weight is X1 for first to KX1-th columns of the parity check matrices H of the second new LDPC codes of (64k, 6/15), (64k, 8/15), (64k, 10/15) and (64k, 12/15), the column weight is X2 for next KY2 columns, the column weight is Y1 (or next KY1 columns, the column weight is Y2 for next KY2 columns, the column weight is 2 for next M−1 columns, and the column weight is 1 for a last column, respectively.
Herein, KX1+KX2+KY1+KY2+M−1+1 to the code length N=64800 bits of the second new LDPC codes of (64k, 6/15), (64k, 8/15), (64k, 10/15) and (64k, 12/15).
As for the parity check matrices H of the second new LDPC codes of (64k, 6/15), (64k, 8/15), (64k, 10/15) and (64k, 12/15), as is the case with the parity check matrix illustrated in
In the simulation, the AWGN channel is supposed, and 50 times is adopted as the number of times of repetitive decoding C for decoding the LDPC code.
In
According to
The column weight is X1 for first to KX1-th columns of the parity check matrices H of the second new LDPC codes of (64k, 7/15), (64k, 9/15), (64k, 11/15) and (64k, 13/15), the column weight is X2 for next KY2 columns, the column weight is Y1 for next KY1 columns, the column weight is Y2 for next KY2 columns, the column weight is 2 for next M−1 columns, and the column weight is 1 for a last column, respectively.
Herein, KX1+KX2+KY1+KY2+M−1+1 is equal to the code length N=16200 bits of the second new LDPC codes of (16k, 7/15), (16k, 9/15), (16k, 11/15) and (16k, 13/15).
As for the parity check matrices H of the second new LDPC codes of (16k, 7/15), (16k, 9/15), (16k, 11/15) and (16k, 13/15), as is the case with the parity check matrix illustrated in
In the simulation, the AWGN channel is supposed as the communication channel 13 (
In
According to
In the transmission system in
In the ATSC3.0, the constellation used in the MODCOD that is a combination of the modulation scheme and the LDPC code is set.
In the ATSC3.0, it is expected to use five modulation schemes, i.e., QPSK, 16QAM, 64QAM, 256QAM and 1024QAM (1kQAM).
In the ATSC3.0, it is expected to use 16 types of the LDPC codes whose code rates r of eight types of 6/15, 7/15, 8/15, 9/15, 10/15, 11/15, 12/15 and 13/15 for each of two types of code lengths N of 16k bits and 64k bits.
In the ATSC3.0, 16 types of the LDPC codes are classified into 8 types (not depending on the code lengths N) by the code rates r, and it is expected that 40 (=8×5) combinations of 8 types of the LDPC codes (each LDPC code whose code rate r is 6/15, 7/15, 8/15, 9/15, 10/15, 11/15, 12/15 or 13/15) and 5 types of the modulation schemes are used as a MODCOD capable of setting the constellation.
Accordingly, in the ATSC3.0, the MODCOD represents the combination of the 8 types of the code rates r of the LDPC codes and 5 types of the modulation schemes.
In
Herein, for example, the “NUC_16_6/15” represents the constellation used in the MODCOD where the modulation scheme is 16QAM and code rate r is the LDPC code is 6/15.
As shown in
Also as shown in
Accordingly, in the ATSC3.0, constellation is prepared for QPSK, and eight constellations are prepared each for 16QAM, 64QAM, 256QAM and 1024QAM.
There are a UC (Uniform Constellation) where a constellation of signal points is uniform and a NUC (Non Uniform Constellation) where a constellation is not uniform.
Also, there are constellations called as 1D NUC (1-dimensional M2-QAM non-uniform constellation), 2D NUC (2-dimensional QQAM non-uniform constellation) and the like.
As the constellation of QPSK, UC is used. As the constellations of 16QAM. 64QAM and 256QAM, 2D NUC is used, for example. As the constellations of 1024QAM, 1D NUC is used, for example.
In
In
The constellations where the code rates r of the LDPC code are 7/15, 9/15, 11/15 and 13/15 are based on the data provided from Samsung.
In
If the modulation scheme is 16QAM, 64QAM or 256QAM, as shown in
If the modulation scheme is 1024QAM, as shown in
In
In
In
In
In
In 2D NUC, a signal point of a second quadrant of the constellation is arranged at a position where the signal point of the first quadrant is moved symmetrically with respect to the Q axis, and a signal paint of a third quadrant of the constellation is arranged at a position where the signal point of the first quadrant is moved symmetrically with respect to the origin. A signal point of a fourth quadrant of the constellation is arranged at a position where the signal point of the first quadrant is moved symmetrically with respect to the I axis.
Herein, if the modulation scheme is 2mQAM, m bits are taken as one symbol, and one symbol is mapped to signal points corresponding to the symbol.
The symbol of the m bit symbol is represented, for example, by 0 to 2m−1 integer values. If b=2m/4, the symbols y(0), y(1), . . . , y(2m−1) represented by 0 to 2m−1 integer values may be classified into four symbols y(0) to y(b−1), y(b) to y(2b−1), y(2b) to y(3b−1) and y(3b) to (4b−1).
In
The coordinate of the signal point corresponding to the symbol y(k+b) from the symbols y(b) to y(2b−1) in represented by −conj(w#k). The coordinate of the signal point corresponding to the symbol y(k+2b) from the symbols y(2b) to y(3b−1) is represented by conj(w#k). The coordinate of the signal point corresponding to the symbol y(k+3b) from the symbols y(3b) to y(4b−1) is represented by conj(w#k).
The conj(w#k) represents a complex conjugate w#k.
For example, if the modulation scheme is 16QAM, m=4 bit symbols; y(0), y(1), . . . , y(15) are classified into four, symbols y(0) to y(3), y(4) to y(7), y(8) to y(11) and y(12) to y(15) as b=244/4=4.
For example, as the symbol y(12) from the symbols y(0) to y(15) is a symbol y(k+3b)y(0+3×4) from the symbols y(3b) to y(4b−1) and k=0, the coordinate of the signal point corresponding to the symbol y(12) will be −w#k=−w0.
If the code rate r of she LDPC code, for example, is 9/15, according to
In
u#k represents a real part Re(zq) and an imaginary pan Im(zq) of the complex number as a coordinate of the signal point zq of 1D NUC.
The 10-bit symbol y of 1024QAM is represented by y0,q, y1,q, y2,q, y3,q, y4,q, y5,q, y6,q, y7,q, y8,q, and y9,q, from the head bit (Most Significant Bit).
If the 10-bit symbol y=(y0,q, y1,q, y2,q, y3,q, y4,q, y5,q, y6,q, y7,q, y8,q and y9,q) of 1024QAM is for example, (0, 0, 1, 0, 0, 1, 1, 1, 0, 0), odd-numbered 5 bits (y0,q, y2,q, y4,q, y6,q and y8,q) are (0, 1, 0, 1, 0) and the even-numbered 5 bits (y1,q, y3,q, y5,q, y7,q, and y9,q) are (0, 0, 1, 1, 0).
In
In
If the code rate r of the LDPC code, for example, is 7/15, according to
Accordingly, in the real part Re(zq) of the signal point zq corresponding to the symbol y=(0, 0, 1, 0, 0, 1, 1, 1, 0, 0), u3=1.04, in Im(zq), u11=6.28. As a result, the coordinate of the signal point zq corresponding to the symbol y=(0, 0, 1, 0, 0, 1, 1, 1, 0, 0) is represented by 1.04+6.28i.
The signal points of 1D NUC are arranged in a matrix on a straight line parallel to the I axis or a straight line parallel to the Q-axis. However, spaces between signal points are not constant. Upon transmission of (data mapped to) the signal points, the average power of the signal points on the constellation is normalized. Normalization is performed by multiplying each signal point zq on the constellation by a reciprocal 1/(√Pave) of a square tool √Pave of a root mean square value Pave, where the root mean square of absolute values of (coordinates of) all signal points on the constellation is represented by Pave.
By the constellations illustrated in
The block interleaver 25 has a storage region called as Part 1 and a storage region called as Part 2.
The Parts 1 and 2 store one bit in a row (horizontal) direction. The number C of columns that are the storage regions for storing the predetermined number of bits in a column (vertical) direction are arranged. The number C is equal to the number of bits m of the symbols.
When the number of bits that are stored by the part 1 columns in the column direction (hereinafter, also referred to as a part-column length) is expressed as R1, and the part column length of the part 2 columns is expressed as R2, (R1+R2)×C equals to the code length N of the target of the LDPC code to be block-interleaved (in the present embodiment, 64800 bits, or 16200 bits).
In addition, a part column length R1 is equal to a multiple of 360 bits that are the number of columns P being the unit of the cyclic structure. A part column length R2 is equal to a remainder when the sum of the part column length R1 of the part 1 and the part column length R2 of the part 2 (hereinafter also referred to as a column length) R1+R2 is divided by 360 bits that are the number of columns P being the unit of the cyclic structure.
Here, the column length R1+R2 is equal to a value when the code length N of the LDPC code to be block-interleaved is divided by the bit number m of symbols.
For example, concerning the LDPC code whose code length N is 16200 bits, if 16QAM is used as the modulation method, the bit number m of symbols is four bits, and the column length R1+R2 will be 4050 (=16200/4) bits.
Furthermore, as the remainder when the column length R1+R2=4050 is divided by 360 bits that are the number of columns P being the unit of the cyclic structure is 90, the part column length R2 will be 90 bits.
The part column length R1 of the part 1 will be R1+R2−R2=4050−90=3960 bits.
The block interleaver 25 preforms the block interleave to the parts 1 and 2 by writing and reading the LDPC code.
In other words, in the block interleave, as shown in
When writing of the code bits to the bottom of the right-most column of the part 1 columns (C-th column) is finished, the rest of the code bits is written from a top to down direction (column direction) of the part 2 columns and from left to right directions of the columns.
After that, what the writing of the code bits to the bottom of the right-most column of the part 2 columns (C-th column) is finished, as shown in
The code bits for all columns of the number C of the part 1 are read sequentially to the lower rows. When the reading is finished for the last R1th row, the code bits are read in a C=m bit unit in the row direction from all first columns of the number C of the part 2.
The code bits for all columns of the number C of the part 2 are read sequentially to the lower rows for the last R2th row.
As described above, the code bits read from the parts 1 and 2 for m-bit unit are supplied to the mapper 117 (
<Group-Wise Interleave>
In the group-wise interleave, the LDPC code for one code word is divided into a 360-bit unit equal to the number of columns P being the unit of the cyclic structure from the beginning. One division, i.e., 360-bit is considered as a bit group. The LDPC code of one code word is interleaved in a bit group unit according to a predetermined pattern (hereinafter also referred to as a GW pattern).
Here, the i+1th bit group from the beginning at the time of dividing the one code word of the LDPC code to the bit group is hereinafter also described as a bit group 1.
For example, the LDPC code whose code length N of 1800 bits is divided into 5(=1800/360) bit groups: 0, 1, 2, 3, 4. Further, for example, the LDPC codes whose code length N of 16200 bits is divided into 45 (=1620/360) bit groups: 0, 1, . . . , 44. The LDPC whose code length N of 64800 bits is divided into 180 (=64800/360) bit groups: 0, 1, . . . , 179.
In the following, the GW pattern will be represented by a sequence of numbers representing the bit groups. For example, for the LDPC code whose code length N of 1800 bits, the GW pattern 4, 2, 0, 3, 2 represents that a sequence of the bit groups 0, 1, 2, 3, 4, is interleaved (changed) to a sequence of the bit groups 4, 2, 0, 3, 1.
The GW pattern can be set for, at least, each code length N of the LDPC code.
According to the GW pattern in
According to the GW pattern in
According to the GW pattern in
According to the GW pattern in
According to the GW pattern in
According to the GW pattern in
According to the GW pattern in
Acceding to the GW pattern in
For the group-wise interleave, the GW pattern is set for each combination of the code rate r of the LDPC code and the modulation scheme other than the code length N of the LDPC code, thereby improving the bit error rate for each combination.
However, if the GW pattern is set individually for all combination of the code length N and code rate r is the LDPC code and the modulation scheme, the GW patient should be changed every time the LDPC code and the modulation scheme used in the transmitting device 11 are changed. As a result, the processing becomes complex.
For the group-wise interleave, for example, the code rate r of the LDPC code is classified into a low rate (e.g., 6/15, 7/15, 8/15, 9/15) and a high rate (e. g., 10/15, 11/15, 12/15, 13/15). The GW pattern can be set for each combination of the code length N of the LDPC code of 16k bits or 64k bits, the code rate r of the LDPC code of the low rate or the high rate, and the modulation scheme of 16QAM, 64QAM, 256QAM or 1024QAM.
When the above-described combination of the code length N, the code rate r and the modulation scheme is expressed by (the code length N, the code rate r, the modulation scheme), 16 combinations of the code length N, the code rate r and the modulation scheme can be supposed: (16k, low rate, 16QAM), (16k, low rate, 64QAM), (16k, low rate, 256QAM), (16k, low rate, 1024QAM), (16k, high rate, 16QAM), (16k, high rate, 64QAM), (16k, high rate, 256QAM), (16k, high rate, 1024QAM), (64k, low rate, 16QAM), (64k, low rate, 64QAM), (64k, low rate, 256QAM), (64k, low rate, 1024QAM), (64k, high rate, 16QAM), (64k, high rate, 64QAM), (64k, high rate, 256QAM) and (64k, high rate, 1024QAM), for example.
For the combination of code length N of the LDPC code set to 64k: (64k, low rate, 16QAM), (64k, low rate, 64QAM), (64k, low rate, 256QAM), (64k, low rate, 1024QAM), (64k, high rate, 16QAM), (64k, high rate, 64QAM), (64k, high rate, 256QAM) and (64k, high rate, 1024QAM). The GW pattern that most improves the error rate can be applied among the four GW patterns shown in
For example, the GW pattern in
For the combination of code length N of the LDPC code is set to 16k: (16k, low rate, 16QAM), (16k, low rate, 64QAM), (16k, low rate, 256QAM), (16k, low rate, 1024QAM), (16k, high rate, 16QAM), (16k, high rate, 64QAM), (16k, high rate, 256QAM), (16k, high rate, 1024QAM), the GW pattern that most improves the error rate can be applied among the four GW patterns shown in
For example, the GW pattern in
According to simulation by the present inventors, for the GW pattern in
For the GW pattern in
For the GW pattern in
For the GW pattern in
For the GW pattern in
For the GW pattern in
For the GW pattern in
For the GW pattern in
An OFDM operation 151 receives the OFDM signal from the transmitting device 11 (
The frame management 152 performs processing of the frame (frame interpretation (configured of the data supplied from the OFDM operation 151 and supplies the signal of the target data and the signal of the control data obtained as a result to frequency deinterleavers 161 and 153.
The frequency deinterleaver 153 performs frequency deinterleave in a symbol unit for the data from the frame management 152 to supply to a demapper 154.
The demapper 154 demaps (performs signal point constellation decoding) the data (data on the constellation) from the frequency deinterleaver 153 based on the signal arrangement (constellation) determined by the orthogonal modulation performed at the transmitting device 11 to perform the orthogonal demodulation thereof and supplies the data ((likelihood) of the LDPC code) obtained as a result to a LDPC decoder 155.
The LDPC decoder 155 performs LDPC decoding of the LDPC code from the demapper 154 and supplies the LDPC larger data (herein, a BCH code) obtained as a result to a BCH decoder 156.
The BCH decoder 156 performs BCH decoding of the LDPC target data from the LDPC decoder 155 and outputs the control data (signaling) obtained as a result.
On the other hand, the frequency deinterleaver 161 performs the frequency deinterleave in a symbol unit for the data from the frame management 152 to supply to a SISO/MISO decoder 162.
The SISO/MISO decoder 162 performs time-space decoding of the data from the frequency deinterleaver 161 to supply to a time deinterleaver 163.
The time deinterleaver 163 performs time deinterleave of the data from the SISO/MISO decoder 162 in a symbol unit to supply to u demapper 164.
The demapper 164 demaps (performs signal point constellation decoding) the data (data on the constellation) from the time deinterleaver 163 based on the signal point arrangement (constellation) determined by the orthogonal modulation performed at the transmitting device 11 to perform the orthogonal demodulation thereof and supplies the data obtained as a result to a bit deinterleaver 165.
The bit deinterleaver 165 performs bit deinterleave of the data from the demapper 164 and supplies (the likelihood of) the LDPC code obtained as a result to an LDPC decoder 166.
The LDPC decoder 166 performs the LDPC decoding of the LDPC code from the bit deinterleaver 165 and supplies the LDPC target data (herein, the BCH code) obtained as a result to a BCH decoder 167.
The BCH decoder 167 performs the BCH decoding of the LDPC target data from the LDPC decoder 155 and supplies the data obtained as a result to a BB descrambler 168.
The BB descrambler 168 applies a BB descramble to the data from the BCH decoder 167 and supplies the data obtained as a result to a null deletion 169.
The null deletion 169 deletes the null inserted by the padder 112 in
The demultiplexer 170 separates one or more streams (target data) multiplexed into the data from the null deletion 169 and outputs the same as output streams.
The receiving device 12 may be configured without including some of the blocks shown in
The bit deinterleaver 165 configured of a block deinterleaver 54 and a group-wise deinterleaver 55 and performs the (bit) deinterleave of the symbol bit of the data from the demapper 164 (
That is to say, the block deinterleaver 54 performs a block deinterleave (an inverse process of block interleave) corresponding to the block interleave performed by the block interleaver 23 in
The group-wise deinterleaver 55 performs group-wise deinterleave (inverse process of the group-wise interleave) corresponding to the group-wise interleave performed by the group-wise interleaver 24 in
If the parity interleave, the group-wise interleave, and the block interleave are applied to the LDPC code supplied from the demapper 164 to the bit deinterleaver 165, the bit deinterleaver 165 may perform all of parity deinterleave (inverse process of the parity interleave, that is to say, the parity deinterleave to return the code bits of the LDPC code, the arrangement of which is changed by the parity interleave, to the original arrangement) corresponding to the parity interleave, the block deinterleave corresponding to the block interleave, and the group-wise deinterleave corresponding to the group-wise interleave.
Note that the bit deinterleaver 165 in
Therefore, the LDPC code, to which the block de-interleave and the group-wise deinterleave are applied and the parity deinterleave is not applied, is supplied from (the group-wise deinterleaver 55 of) the bit deinterleaver 165 to the LDPC decoder 166.
The LDPC decoder 166 performs the LDPC decoding of the LDPC code from the bit deinterleaver 165 using the conversion parity check matrix obtained by at least applying the column permutation corresponding to the parity interleave to the parity check matrix H used by the LDPC encoder 115 in
At step S111, the demapper 164 demaps the data from the time deinterleaver 163 (data mapped onto the signal point on the constellation) to perform the orthogonal demodulation and supplies the same to the bit deinterleaver 165, then the process shifts to S112.
At step S112, the bit deinterleaver 165 performs the deinterleave (bit deinterleave) from the demapper 164 and the process shifts to step S113.
That is to say, at step S112, the block deinterleaver 54 performs in the bit deinterleaver 165 the block deinterleave of the data (symbol) from the demapper 164 and supplies the code bit of the LDPC code obtained as a result to the group-wise deinterleaver 55.
The group-wise deinterleaver 55 performs the group-wise deinterleave to the LDPC code from the block deinterleaver 54 and supplies (the likelihood of) the LDPC code obtained as a result to the LDPC decoder 166.
At step S113, the LDPC decoder 166 performs the LDPC decoding of the LDPC code from the group-wise deinterleaver 55 using the conversion parity check matrix H used by the LDPC encoder 115 in
Although the block deinterleaver 54, which performs the block deinterleave, and the group-wise deinterleaver 55, which performs the group-wise deinterleave, are separately formed also in
The LDPC decoding performed by the LDPC decoder 166 in
The LDPC decoder 166 in
Herein, the LDPC decoding capable of limiting an operation frequency within a sufficiently feasible range while limiting a circuit size by performing the LDPC decoding using the conversion parity check matrix is conventionally suggested (refer to U.S. Pat. No. 4,224,777, for example).
Firstly, the LDPC decoding using the conversion parity check matrix conventionally suggested is first described with reference to
In
In the parity check matrix H in
Row permutation: 6s+t+first row−>t+s+first row (11)
Column permutation: 6x+y+61th−>5y+x+61th row (12)
In equations (11) and (12), s, t, x, and y are integers within a range satisfying 0≦s<5, 0≦t<6, 0≦x<5, and 0≦t<6, respectively.
According to the row permutation in equation (11), it is permutated such that 1st, 7th, 13th, 19th, and 25th rows, which leave a remainder of 1 when divided by 6, are made 1st, 2nd, 3rd, 4th, and 5th rows, and 2nd, 8th, 14th, 20th, and 26th rows, which leave a remainder of 2 when divided by 6, are made 6th, 7th, 8th, 9th, and 10th rows, respectively.
Also, according to the column permutation in equation (12), it is permutated such that 61st, 67th, 73rd, 79th, and 85th columns, which leave a remainder of 1 when divided by 6, are made 61st, 62nd, 63rd, 64th, and 65th columns, and 62nd, 68th, 74th, 80th, and 86th columns, which leave a remainder of 2 when divided by 6, are made 66th, 67th, 68th, 69th, and 70th columns, respectively, for the 61st and subsequent columns (parity matrix).
The matrix obtained by performing the row permutation and the column permutation of the parity check matrix H in
Herein, the row permutation of the parity check matrix H does not affect the arrangement of the code bits of the LDPC code.
The column permutation in equation (12) corresponds to the parity interleave when the information length K, the number of columns P being the unit of the cyclic structure, and the submultiple q (=M/P) of the parity length M (herein, 30) of the above-described parity interleave to interleave the K+qx+y+1th code bit to the position of the K+Py+x+1-th code bit are set to 60, 5, and 6, respectively.
Accordingly, the parity check matrix H′ in
By multiplying the parity check matrix H′ in
From above, the conversion parity check matrix H′ in
Therefore, by applying the column permutation in equation (12) to the LDPC code c of the original parity check matrix H, decoding (LDPC decoding) the LDPC code c′ after the column permutation using the conversion parity check matrix H′ in
In
It may be said that the conversion parity check matrix H′ in
An architecture to simultaneously perform P check node operations and P variable node operations may be used to decode the LDPC code of the parity check matrix represented by a P×P constitutive matrix.
That is to say,
The decoding device in
A method of storing the data in the edge data storage memories 300 and 304 is first described.
The edge data storage memory 300 is configured of six FIFOs 3001to 3006, the number of which is obtained by dividing the number of rows 30 of the conversion parity check matrix H′ in
The data corresponding to the position of 1 from first to fifth rows of the conversion parity check matrix H′ in
The data corresponding to the position of 1 from 6th to 10th rows of the conversion parity check matrix H′ in
That is to say, as for the constitutive matrix whose weight is 2 or larger, the data corresponding to the position of 1 of the unit matrix, the quasi-unit matrix, and the shift matrix whose weight is 1 (message corresponding to the edge belonging to the unit matrix, the quasi-unit matrix, or the shift matrix) when the constitutive matrix is represented as the sum of a plurality of the P×P unit matrix whose weight is 1, the quasi-unit matrix in which one or more of the elements 1 of the unit matrix is set to 0, and the shift matrix obtained by the cyclic shift of the unit matrix or the quasi-unit matrix is stored in the same address (same FIFO out of the FIFOs 3001 to 3006.
The data is hereinafter stored in association with the conversion parity check matrix H′ also in the storage regions of third to ninth stages.
The data is stored in association with the conversion parity check matrix H′ also in the FIFOs 3003 to 3006.
The edge data storage memory 304 is configured of 18 FIFOs 3041 to 30418, the number of which is obtained by dividing the number of columns 90 of the conversion parity check matrix H′ by the number of columns 5 of the constitutive matrix (the number of columns P being the unit of the cyclic structure). The FIFO 304x (x=1, 2, . . . 18) is formed of a plurality of stages of storage regions, and the messages corresponding to the five edges, the number of which is the number of rows and the number of columns of the constitutive matrix (the number of columns P being the unit of the cyclic structure) may be simultaneously read and written from and to the storage region of each stage.
In the FIFO 3041, the data corresponding to the position of 1 from first to fifth columns of the conversion parity check matrix H′ in
That is to say, as for the constitutive matrix whose weight is 2 or larger, the data corresponding to the position of 1 of the unit matrix, the quasi-unit matrix, and the shift matrix whose weight is 1 (the message corresponding to the edge belonging to the unit matrix, the quasi-unit matrix, or the shift matrix) when the constitutive matrix is represented as the sum of a plurality of the P×P unit matrix whose weight is 1, the quasi-unit matrix in which one or more of the elements 1 of the unit matrix is set to 0, and the shift matrix obtained by the cyclic shift of the unit matrix or the quasi-unit matrix is stored in the same address (same FIFO out of the FIFOs 3041 to 30418).
Hereinafter, the data is stored in the storage regions of fourth and fifth stages in association with the conversion parity check matrix H′. The number of stages of the storage regions of the FIFO 3041 is five being the maximum number of the number of 1 in the row direction from the first to fifth columns of the conversion parity check matrix H′ (Hamming weight).
The data is similarly stored in association with the conversion parity check matrix H′ in the FIFOs 3042 and 3043, the length (the number of stages) of which is five. The data is similarly stored in association with the conversion parity check matrix H′ in the FIFOs 3044 to 30412, the length of which is three. The data is similarly stored in association with the conversion parity check matrix H′ in the FIFOs 30413 to 30418, the length of which is two.
Next, operation of the decoding device in
The edge data storage memory 300 is configured of the six FIFOs 3001 to 3006, selects the FIFO in which the data is stored from the FIFOs 3001 to 3006 according to information (matrix data) D312 indicating the row of the conversion parity check matrix H′ in
The selector 301 selects the five messages from the FIFO from which the data is currently read out of the FIFOs 3001 to 3001 according to a select signal D301 and supplies the same as a message D302 to the check node calculation unit 302.
The check node calculation unit 302 configured of five check node calculators 3021 to 3021 performs the check node operation according to equation (7) using the messages D302 (D3021 to D3025) supplied through the selector 301 (message v1 in equation (7)) and supplies five messages D303 (D3031 to D3035) obtained as a result of the check node operation (message uj in equation (7)) to the cyclic shift circuit 303.
The cyclic shift circuit 303 performs the cyclic shift of the five messages D3031 to D3035 obtained by the check node calculation unit 302 based on information (matrix data) D305 indicating the value by which the cyclic shift of the original unit matrix (or the quasi-unit matrix) in the conversion parity check matrix H′ is performed to obtain the corresponding edge and supplies a result to the edge data storage memory 304 as a message D304.
The edge data storage memory 304 is configured of 18 FIFOs 3041 to 30418, selects the FIFO in which the data is stored from the FIFOs 3041 to 30418 according to the information D305 indicating the row of the conversion parity check matrix H′ to which the five messages D304 supplied from the cyclic shift circuit 303 in the preceding stage belongs, and collectively stores the five messages D304 in the selected FIFO in sequence. When reading the data, the edge data storage memory 304 reads the five messages D3061 in sequence from the FIFO 3041 to supply to the selector 305 in the subsequent stage. The edge data storage memory 304 reads the message in sequence also from the FIFOs 3042 to 30418 after finishing reading the data from the FIFO 3041 to supply to the selector 305.
The selector 305 selects the five messages from the FIFO from which the data is currently read out of the FIFOs 3041 to 30418 according to a select signal D307 and supplies the same to the variable node calculation unit 307 and the decoded word calculation unit 309 as a message D308.
On the other hand, the received data rearrangement unit 310 rearranges an LDPC code D313 received through the communication channel 13 corresponding to the parity check matrix H in
The variable node calculation unit 307 is configured of five variable node calculators 3071 to 3075, performs the variable node operation according to equation (1) using the messages D308 (D3081 to D3085) supplied through the selector 305 (message uj in equation (1) and the five received values D309 supplied from the received data memory 306 (received value u01 in equation (1)) and supplies messages D310 (D3101 to D3105) obtained as a result of the operation (message vi in equation (1)) to the cyclic shift circuit 308.
The cyclic shift circuit 308 performs the cyclic shift of the messages D3101 to D3105 calculated by the variable node calculation unit 307 based on the information indicating the value by which the cyclic shift of the original unit matrix (or the quasi-unit matrix) in the conversion parity check matrix H′ is performed to obtain the corresponding edge and supplies a result to the edge data storage memory 300 as a message D311.
Single decoding (variable node operation and check node operation) of the LDPC code may be performed by single round of the above-described operation. The decoding device in
That is to say, the decoded word calculation unit 309 is configured of five decoded word calculators 3091 to 3095, calculates the decoding result (decoded word) based on equation (5) as a final stage of a plurality of times of decoding using the five messages D308 (D3081 to D3085) (message uj in equation (5)) output by the selector 305 and the five received values D309 (received value u0i in equation (5)) supplied from the received data memory 306, and supplies decoded data D315 obtained as a result to the decoded data rearrangement unit 311.
The decoded data rearrangement unit 311 applies the inverse permutation of the column permutation in equation (12) to the decoded data D315 supplied from the decoded word calculation unit 309, thereby rearranging an order thereof and outputs the same as a final decoded result D316.
As described above, by applying any one or both of the row permutation and the column permutation to the parity check matrix (original parity check matrix) and converting the same to the parity check matrix (conversion purity check matrix) represented by the combination of the P×P unit matrix, the quasi-unit matrix in which one or more of the elements of 1 of the unit matrix is set to 0, the shift matrix obtained by the cyclic shift of the unit matrix or the quasi-unit matrix, the sum matrix obtained by summing a plurality of the unit matrix, the quasi-unit matrix, and the shift matrix, and the P×P 0 matrix, that is to say, the combination of the constitutive matrices, it becomes possible to adopt the architecture to simultaneously perform the P check node operations and the P variable node operations as the decoding of the LDPC code where P is fewer than the numbers of the columns and rows in the parity. When it adopts the architecture to simultaneously perform the P check node operations and the P variable node operations as the decoding of the LDPC code where P is fewer than the numbers of the columns and rows in the parity check matrix, the operation frequency may be limited within the feasible range to perform a great number of times of repetitive decoding, as compared to a case that the node operations are performed at the same time for the same numbers of the numbers of the columns and rows in the parity check matrix.
The LDPC decoder 166, which configures the receiving device 12 in
That is to say, in order to simplify the description, supposing that the parity check matrix of the LDPC code output by the LDPC encoder 115 configuring the transmitting device 11 in
The parity interleave corresponds to the column permutation in equation (12) as described above, so that the LDPC decoder 166 is not required to perform the column permutation in equation (12).
Therefore, in the receiving device 12 in
That is to say,
In
As described above, the LDPC decoder 166 may be reconfigured without the received data rearrangement unit 310, so that a scale thereof may be made smaller than that of the decoding device in
Although the code length N in the LDPC code, the information length K, the number of columns (the number of rows and the number of columns of the constitutive matrix) being the unit of the cyclic structure P, and the submultiple q (=M/P) of the parity length M in the LDPC code are set to 90, 60, 5, and 6, respectively, in
That is to say, in the transmitting device 11 in
The block deinterleaver 54 is configured similar to the block deinterleaver 25 illustrated in
The block deinterleaver 54 has a storage region called as Part 1 and a storage region called as Part 2. The Parts 1 and 2 store one bit in a row direction. The number C of columns that are the storage regions for storing the predetermined number of bits in a column direction are arranged. The number C is equal to the number of bits m of the symbols.
The block deinterleaver 54 preforms the block deinterleave to the parts 1 and 2 by writing and reading the LDPC code.
In the block deinterleave, the LDPC code (as the symbol) is written in an order that the block interleaver in
Further, in the block deinterleave, the LDPC code is read in an order that the block interleaver 25 in
That is to say, in the block interleave by the block interleaver 25 in
In the drawing, the same reference numeral is assigned to a part corresponding to that in
That is to say, the bit deinterleaver 165 in
In
That is to say, the block deinterleaver 54 performs the block deinterleave (inverse process of the block interleave) corresponding to the block interleave performed by the block interleaver 25 of the transmitting device 11 for the LDPC code from the demapper 164, i.e., the block deinterleave to return the position of the code bit interchanged by the block interleave to the original position, and supplies the LDPC code obtained as a result to the group-wise deinterleaver 55.
The group-wise deinterleaver 55 applies the group-wise deinterleave corresponding to the group-wise interleave as the rearranging process performed by the group-wise interleaver 24 of the transmitting device 11 to the LDPC code from the block deinterleaver 54.
The LDPC code obtained as a result of the group-wise deinterleave is supplied from the group-wise deinterleaver 55 to the parity deinterleaver 1011.
The parity deinterleaver 1011 applies the parity deinterleave (inverse process of the parity interleave) corresponding to the parity interleave performed by the parity interleaver 23 of the transmitting device 11, that is to say, the parity deinterleave to return the code bit of the LDPC code, the arrangement of which is changed by the parity deinterleave, to the original arrangement for the code bit after the group-wise deinterleave by the group-wise deinterleaver 55.
The LDPC code obtained as a result of the parity deinterleave is supplied from the parity deinterleaver 1011 to the LDPC decoder 166.
Therefore, in the bit deinterleaver 165 in
The LDPC decoder 166 performs the LDPC decoding of the LDPC code from the bit deinterleaver 165 using the parity check matrix H used by the LDPC encoder 115 of the transmitting device 11. That is to say, the LDPC decoder 166 performs the LDPC decoding of the LDPC code from the bit deinterleaver 165 using the parity check matrix H itself used by the LDPC encoder 115 of the transmitting device 11 in the LDPC encoding or the conversion parity check matrix obtained by at least applying the column permutation corresponding to the parity interleave to the parity check matrix H.
Herein, in
Also, when the LDPC decoder 166 performs the LDPC decoding of the LDPC code using the conversion parity check matrix obtained by at least performing the column permutation corresponding to the parity interleave of the parity check matrix H used by the LDPC encoder 115 of the transmitting device 11 in the LDPC encoding, the LDPC decoder 166 may be configured of the decoding device of the architecture to simultaneously perform the P (or submultiple of P other than 1) check node operations and variable node operations being the decoding device (
Although the block deinterleaver 54, which performs the block deinterleave, the group-wise deinterleaver 55, which performs the group-wise deinterleave, and the parity deinterleaver 1011, which performs the parity deinterleave, are separately formed for convenience of description in
In
The obtaining unit 1101 obtains a signal including the LDPC cede obtained by at least the LDPC encoding of the LDPC target data such as the image data and the audio data of the program through a transmission channel (communication channel) (not shown) such as digital terrestrial broadcasting, digital satellite broadcasting, and a network such as a CATV network, the Internet and the like, for example, to supply to the transmission channel decoding processor 1102.
Herein, if the signal obtained by the obtaining unit 1101 is broadcasted from a broadcasting station through the terrestrial wave, a satellite wave, the CATV (cable television) network and the like, for example, the obtaining unit 1101 is configured of a tuner, an STB (set top box) and the like. When the signal obtained by the obtaining unit 1101 is multicast-transmitted from a web server such as IPTV (Internet protocol television), for example, the obtaining unit 1101 is configured of a network I/F (interface) such as an NIC (network interface card), for example.
The transmission channel decoding processor 1102 corresponds to the receiving device 12. The transmission channel decoding processor 1102 applies a transmission channel decoding process at least including a process to correct the error occurring in the transmission channel to the signal obtained by the obtaining unit 1101 through the transmission channel and supplies the signal obtained as a result to the information source decoding processor 1103.
That is to say, the signal obtained by the obtaining unit 1101 through the transmission channel is the signal obtained by at least the error correction encoding for correcting the error occurring in the transmission channel and the transmission channel decoding processor 1102 applies the transmission channel decoding process such as an error correction process, for example, to such signal.
Herein, the error correction encoding includes the LDPC encoding, BCH encoding and the like, for example. Herein, the LDPC encoding is at least performed as the error correction encoding.
Also, the transmission channel decoding process may include demodulation of a modulated signal and the like.
The information source decoding processor 1103 applies an information source decoding process at least including a process to expand compressed information to original information to the signal to which the transmission channel decoding process is applied.
That is to say, there is a case in which compression encoding to compress the information is applied to the signal obtained by the obtaining unit 1101 through the transmission channel so as to decrease a data volume of the image and the audio as the information, and in this case, the information source decoding processor 1103 applies the information source decoding process such as the process to expand the compressed information to the original information (expanding process) to the signal to which the transmission channel decoding process is applied.
If the compression encoding is not applied to the signal obtained by the obtaining unit 1101 through the transmission channel, the information source decoding processor 1103 does not perform the process to expand the compressed information to the original information.
Herein, the expanding process includes MPEG decoding and the like, for example. Also, the transmission channel decoding process might include descrambling and the like in addition to the expanding process.
In the receiving system configured as above, the obtaining unit 1101 applies the compression encoding such as MPEG encoding to the data of the image and the audio, for example, and obtains the signal to which the error correction encoding such as the LDPC encoding is applied through the transmission channel to supply to the transmission channel decoding processor 1102.
The transmission channel decoding processor 1102 applies the process similar to that performed by the receiving device 12 and the like to the signal from the obtaining unit 1101 as the transmission channel decoding process, for example, and the signal obtained as a result is supplied to the information source decoding processor 1103.
The information source decoding processor 1103 applies the information source decoding process such as the MPEG decoding to the signal from the transmission channel decoding processor 1102 and outputs the image or the audio obtained as a result.
The receiving system in
It is possible to form each of the obtaining unit 1101, the transmission channel decoding processor 1102, and the information source decoding processor 1103 as one independent device (hardware (IC (integrated circuit) and the like) or a software module).
Also, as for the obtaining unit 1101, the transmission channel decoding processor 1102, and the information source decoding processor 1103, it is possible to form a set of the obtaining unit 1101 and the transmission channel decoding processor 1102, a set of the transmission channel decoding processor 1102 and the information source decoding processor 1103, and a set of the obtaining and 1101, the transmission channel decoding processor 1102, and the information source decoding processor 1103 as one independent device.
Meanwhile, in the drawing, the same reference numeral is assigned to a part corresponding to that in
The receiving system in
The output unit 1111 is a display device, which displays the image, and a speaker, which outputs the audio, for example, and this outputs the image, the audio and the like as the signal output from the information source decoding processor 1103. That is to say, the output unit 1111 displays the image or outputs the audio.
The receiving system in
If the compression encoding is not applied to the signal obtained by the obtaining unit 1101, the signal output by the transmission channel decoding processor 1102 is supplied to the output unit 1111.
In the drawing, the same reference numeral is assigned to a part corresponding to that in
The receiving system in
However, the receiving system in
The record unit 1121 records (stores) the signal output from the transmission channel decoding processor 1102 (for example, a TS packet of MPEG TS) in a recording (storage) medium such as an optical disk, a hard disk (magnetic disk), and a flash memory.
The receiving system in
In
A series of processes described above may be performed by hardware or by software. When a series of processes is performed by the software, a program, which configures the software, is installed on a multi-purpose computer and the like.
The program may be recorded in advance in a hard disk 705 and a ROM 703 as a recording medium stored in the computer.
Alternatively, the program may be temporarily or permanently stored (recorded) in a removable recording medium 711 such as a flexible disk, a CD-ROM (compact disc read only memory), an MO (magnetooptical) disk, a DVD (digital versatile disc), the magnetic disk, and a semiconductor memory. Such removable recording medium 711 may be provided as so-called packaged software.
In addition to installation from the above-described removable recording medium 711 on the computer, the program may be transferred from a downloading site to the computer by wireless through a satellite for the digital satellite broadcasting or transferred to the computer by wire through the network such as a LAN (local area network) and the Internet, and the computer may receive the program transferred in this manner by a communication unit 708 to install on an internal hard disk 705.
The computer has a CPU (central processing unit) 702 built-in. An input/output interface 710 is connected to the CPU 702 through a bus 701 and, when an instruction is input through the input/output interface 710 by operation and the like of the input unit 707 configured of a keyboard, a mouse, a microphone and the like by a user, the CPU 702 executes the program stored in the ROM (read only memory) 703 according to the same. Alternatively, the CPU 702 loads the program stored in the hard disk 705, the program transferred from the satellite or the network to be received by the communication unit 708 and installed on the hard disk 705, or the program read from the removable recording medium 711 mounted on a drive 709 to be installed on the hard disk 705 on a RAM (random access memory) 704 to execute. According to this, the CPU 702 performs the process according to the above-described flowchart or the process performed by the configuration of the above-described block diagram. Then, the CPU 702 outputs a processing result from an output unit 706 configured of an LCD (liquid crystal display), a speaker and the like, or transmits the same from the communication unit 708, or records the same in the hard disk 705 through the input/output interface 710, for example, as needed.
Herein, in this specification, a processing step to write the program to allow the computer to perform various processes is not necessarily required to be processed in chronological order along order described in the flowchart and this also includes the process executed in parallel or individually executed (for example, a parallel process or a process by an object).
Also, the program may be processed by one computer or distributedly processed by a plurality of computers. Further, the program may be transferred to a remote computer to be executed.
The embodiment of the present technology is not limited to the above-described embodiment and various modifications may be made without departing from the scope of the present technology.
For example, (the parity check matrix initial value table of) the above-described new LDPC code may be through the communication channel 13 (
The above-described GW patterns may be applied to any other than the new LDPC code. Furthermore, the modulation scheme to which the above-described GW patterns are applied is not limited to 16QAM, 64QAM, 256QAM and 1024QAM.
Effects described herein are not limited only to be illustrative, there may be effects other than those described herein.
Number | Date | Country | Kind |
---|---|---|---|
2013-199089 | Sep 2013 | JP | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2014/074200 | 9/12/2014 | WO | 00 |