Modulator and modulation method using non-uniform 16-symbol signal constellation for low-density parity check codeword having 4/15 code rate
09735806 · 2017-08-15
Assignee
Inventors
- Sung-Ik Park (Daejeon, KR)
- Sun-Hyoung Kwon (Daejeon, KR)
- Jae-Young Lee (Daejeon, KR)
- Heung-Mook Kim (Daejeon, KR)
- Nam-Ho Hur (Sejong, KR)
Cpc classification
H03M13/2792
ELECTRICITY
H03M13/1165
ELECTRICITY
H04L1/0042
ELECTRICITY
H03M13/616
ELECTRICITY
H04L27/3422
ELECTRICITY
International classification
H04L27/34
ELECTRICITY
H03M13/25
ELECTRICITY
H04L1/00
ELECTRICITY
Abstract
A modulator and a modulation method using a non-uniform 16-symbol signal constellation are disclosed. The modulator includes a memory and a processor. The memory receives a codeword corresponding to a low-density parity check (LDPC) code having a code rate of 4/15. The processor maps the codeword to 16 symbols of the non-uniform 16-symbol signal constellation on a 4-bit basis.
Claims
1. A modulator using a non-uniform 16-symbol signal constellation, comprising: a memory configured to receive a codeword corresponding to a low-density parity check (LDPC) code having a code rate of 4/15; and a processor configured to map the codeword to 16 symbols of the non-uniform 16-symbol signal constellation on a 4-bit basis, thereby generating a modulated signal, wherein the 16 symbols are defined as shown in the following Table: TABLE-US-00007 TABLE W Constellation 0 0.3412 + 0.5241i 1 0.5241 + 0.3412i 2 0.5797 + 1.1282i 3 1.1282 + 0.5797i 4 −0.3412 + 0.5241i 5 −0.5241 + 0.3412i 6 −0.5797 + 1.1282i 7 −1.1282 + 0.5797i 8 0.3412 − 0.5241i 9 0.5241 − 0.3412i 10 0.5797 − 1.1282i 11 1.1282 − 0.5797i 12 −0.3412 − 0.5241i 13 −0.5241 − 0.3412i 14 −0.5797 − 1.1282i 15 −1.1282 − 0.5797i, and wherein the modulated signal corresponds to a transmission signal, the transmission signal being transmitted to a reception device.
2. The modulator of claim 1, wherein the LDPC code is interleaved on a bit group basis before mapping the codeword to the non-uniform 16-symbol signal constellation.
3. The modulator of claim 2, wherein the LDPC code is interleaved using the following equation using permutation order:
Y.sub.j=X.sub.π(j) 0≦j≦N.sub.group where X.sub.π(j) is a π(j)th bit group, Y.sub.j is an interleaved j-th bit group, N.sub.group is a number of bit groups, and π(j) is a permutation order for bit group-based interleaving.
4. The modulator of claim 1, wherein the LDPC code is generated by performing accumulation at parity bit addresses of a memory, the parity bit addresses updated using a sequence corresponding to a parity check matrix (PCM).
Description
BRIEF DESCRIPTION OF THE DRAWINGS
(1) The above and other objects, features and advantages of the present invention will be more clearly understood from the following detailed description taken in conjunction with the accompanying drawings, in which:
(2)
(3)
(4)
(5)
(6)
(7)
(8)
(9)
(10)
(11)
(12)
DETAILED DESCRIPTION
(13) Embodiments of the present invention will be described in detail below with reference to the accompanying drawings. Repeated descriptions and descriptions of well-known functions and configurations that have been deemed to make the gist of the present invention unnecessarily obscure will be omitted below. The embodiments of the present invention are intended to fully describe the present invention to persons having ordinary knowledge in the art to which the present invention pertains. Accordingly, the shapes, sizes, etc. of components in the drawings may be exaggerated to make the description obvious.
(14) Embodiments of the present invention are described in detail below with reference to the accompanying drawings.
(15)
(16) Referring to
(17) The BICM device 10 generates an n-bit codeword by encoding k information bits 11 using an error-correction coder 13. In this case, the error-correction coder 13 may be an LDPC coder or a Turbo coder.
(18) The codeword is interleaved by a bit interleaver 14, and thus the interleaved codeword is generated.
(19) In this case, the interleaving may be performed on a bit group basis (by a unit of a bit group). In this case, the error-correction coder 13 may be an LDPC coder having a length of 16200 and a code rate of 4/15. A codeword having a length of 16200 may be divided into a total of 45 bit groups. Each of the bit groups may include 360 bits, i.e., the parallel factor of an LDPC codeword.
(20) In this case, the interleaving may be performed on a bit group basis (by a unit of a bit group) in accordance with an interleaving sequence, which will be described later.
(21) In this case, the bit interleaver 14 prevents the performance of error correction code from being degraded by effectively distributing burst errors occurring in a channel. In this case, the bit interleaver 14 may be separately designed in accordance with the length and code rate of the error correction code and the modulation order.
(22) The interleaved codeword is modulated by a modulator 15, and is then transmitted via an antenna 17.
(23) In this case, the modulator 15 may be based on a concept including symbol mapper (symbol mapping device). In this case, the modulator 15 may be a symbol mapping device performing 16-symbol mapping which maps codes onto 16 constellations (symbols).
(24) In this case, the modulator 15 may be a uniform modulator, such as a quadrature amplitude modulation (QAM) modulator, or a non-uniform modulator.
(25) The modulator 15 may be a symbol mapping device performing NUC (Non-Uniform Constellation) symbol mapping which uses 16 constellations (symbols). That is, the modulator 15 may map the interleaved codeword to the 16 symbols of the non-uniform 16-symbol signal constellation on a 4-bit basis.
(26) The signal transmitted via the wireless channel 20 is received via the antenna 31 of the BICM reception device 30, and, in the BICM reception device 30, is subjected to a process reverse to the process in the BICM device 10. That is, the received data is demodulated by a demodulator 33, is deinterleaved by a bit deinterleaver 34, and is then decoded by an error correction decoder 35, thereby finally restoring the information bits.
(27) It will be apparent to those skilled in the art that the above-described transmission and reception processes have been described within a minimum range required for a description of the features of the present invention and various processes required for data transmission may be added.
(28)
(29) Referring to
(30) That is, at step S210, an n-bit codeword is generated by encoding k information bits using the error-correction coder.
(31) In this case, step S210 may be performed as in an LDPC encoding method, which will be described later.
(32) Furthermore, in the broadcast signal transmission and reception method, an interleaved codeword is generated by interleaving the n-bit codeword on a bit group basis at step S220.
(33) In this case, the n-bit codeword may be an LDPC codeword having a length of 16200 and a code rate of 4/15. The codeword having a length of 16200 may be divided into a total of 45 bit groups. Each of the bit groups may include 360 bits corresponding to the parallel factors of an LDPC codeword.
(34) In this case, the interleaving may be performed on a bit group basis (by a unit of a bit group) in accordance with an interleaving sequence, which will be described later.
(35) Furthermore, in the broadcast signal transmission and reception method, the encoded data is modulated at step S230.
(36) That is, at step S230, the interleaved codeword is modulated using the modulator.
(37) In this case, the modulator may be based on a concept including symbol mapper (symbol mapping device). In this case, the modulator may be a symbol mapping device performing 16-symbol mapping which maps codes onto 16 constellations (symbols).
(38) In this case, the modulator may be a uniform modulator, such as a QAM modulator, or a non-uniform modulator.
(39) The modulator may be a symbol mapping device performing NUC (Non-Uniform Constellation) symbol mapping which uses 16 constellations (symbols).
(40) Furthermore, in the broadcast signal transmission and reception method, the modulated data is transmitted at step S240.
(41) That is, at step S240, the modulated codeword is transmitted over the wireless channel via the antenna.
(42) Furthermore, in the broadcast signal transmission and reception method, the received data is demodulated at step S250.
(43) That is, at step S250, the signal transmitted over the wireless channel is received via the antenna of the receiver, and the received data is demodulated using the demodulator.
(44) Furthermore, in the broadcast signal transmission and reception method, the demodulated data is deinterleaved at step S260. In this case, the deinterleaving of step S260 may be reverse to the operation of step S220.
(45) Furthermore, in the broadcast signal transmission and reception method, the deinterleaved codeword is subjected to error correction decoding at step S270.
(46) That is, at step S270, the information bits are finally restored by performing error correction decoding using the error correction decoder of the receiver.
(47) In this case, step S270 corresponds to a process reverse to that of an LDPC encoding method, which will be described later.
(48) An LDPC code is known as a code very close to the Shannon limit for an additive white Gaussian noise (AWGN) channel, and has the advantages of asymptotically excellent performance and parallelizable decoding compared to a turbo code.
(49) Generally, an LDPC code is defined by a low-density parity check matrix (PCM) that is randomly generated. However, a randomly generated LDPC code requires a large amount of memory to store a PCM, and requires a lot of time to access memory. In order to overcome these problems, a quasi-cyclic LDPC (QC-LDPC) code has been proposed. A QC-LDPC code that is composed of a zero matrix or a circulant permutation matrix (CPM) is defined by a PCM that is expressed by the following Equation 1:
(50)
(51) In this equation, J is a CPM having a size of L×L, and is given as the following Equation 2. In the following description, L may be 360.
(52)
(53) Furthermore, J.sup.i is obtained by shifting an L×L identity matrix I (J.sup.0) to the right i (0≦i<L) times, and J.sup.∞ is an L×L zero matrix. Accordingly, in the case of a QC-LDPC code, it is sufficient if only index exponent i is stored in order to store J.sup.i, and thus the amount of memory required to store a PCM is considerably reduced.
(54)
(55) Referring to
(56)
where I.sub.L×L is an identity matrix having a size of L×L.
(57) That is, the matrix B may be a bit-wise dual diagonal matrix, or may be a block-wise dual diagonal matrix having identity matrices as its blocks, as indicated by Equation 3. The bit-wise dual diagonal matrix is disclosed in detail in Korean Patent Application Publication No. 2007-0058438, etc.
(58) In particular, it will be apparent to those skilled in the art that when the matrix B is a bit-wise dual diagonal matrix, it is possible to perform conversion into a Quasi-cyclic form by applying row or column permutation to a PCM including the matrix B and having a structure illustrated in
(59) In this case, N is the length of a codeword, and K is the length of information.
(60) The present invention proposes a newly designed QC-LDPC code in which the code rate thereof is 4/15 and the length of a codeword is 16200, as illustrated in the following Table 1. That is, the present invention proposes an LDPC code that is designed to receive information having a length of 4320 and generate an LDPC codeword having a length of 16200.
(61) Table 1 illustrates the sizes of the matrices A, B, C, D and Z of the QC-LDPC code according to the present invention:
(62) TABLE-US-00002 TABLE 1 Code Sizes rate Length A B C D Z 4/15 16200 1080 × 1080 × 10800 × 10800 × 1080 × 4320 1080 5400 10800 10800
(63) The newly designed LDPC code may be represented in the form of a sequence (progression), an equivalent relationship is established between the sequence and matrix (parity bit check matrix), and the sequence may be represented, as follows:
(64) TABLE-US-00003 Sequence Table 1st row: 19 585 710 3241 3276 3648 6345 9224 9890 10841 2nd row: 181 494 894 2562 3201 4382 5130 5308 6493 10135 3rd row: 150 569 919 1427 2347 4475 7857 8904 9903 4th row: 1005 1018 1025 2933 3280 3946 4049 4166 5209 5th row: 420 554 778 6908 7959 8344 8462 10912 11099 6th row: 231 506 859 4478 4957 7664 7731 7908 8980 7th row: 179 537 979 3717 5092 6315 6883 9353 9935 8th row: 147 205 830 3609 3720 4667 7441 10196 11809 9th row: 60 1021 1061 1554 4918 5690 6184 7986 11296 10th row: 145 719 768 2290 2919 7272 8561 9145 10233 11st row: 388 590 852 1579 1698 1974 9747 10192 10255 12nd row: 231 343 485 1546 3155 4829 7710 10394 11336 13rd row: 4381 5398 5987 9123 10365 11018 11153 14th row: 2381 5196 6613 6844 7357 8732 11082 15th row: 1730 4599 5693 6318 7626 9231 10663
(65) An LDPC code that is represented in the form of a sequence is being widely used in the DVB standard.
(66) According to an embodiment of the present invention, an LDPC code presented in the form of a sequence is encoded, as follows. It is assumed that there is an information block S=(s.sub.0, s.sub.1, . . . , s.sub.K−1) having an information size K. The LDPC encoder generates a codeword Λ=(λ.sub.0, λ.sub.1, λ.sub.2, . . . , λ.sub.N−1) having a size of N=K+M.sub.1+M.sub.2 using the information block S having a size K. In this case, M.sub.1=g, and M.sub.2=N−K−g. Furthermore, M.sub.1 is the size of parity bits corresponding to the dual diagonal matrix B, and M.sub.2 is the size of parity bits corresponding to the identity matrix D. The encoding process is performed, as follows:
(67) Initialization:
λ.sub.i=s.sub.i for i=0,1, . . . ,K−1
p.sub.j=0 for j=0,1, . . . ,M.sub.1+M.sub.2−1 (4)
(68) First information bit λ.sub.0 is accumulated at parity bit addresses specified in the 1st row of the sequence of the Sequence Table. For example, in an LDPC code having a length of 16200 and a code rate of 4/15, an accumulation process is as follows:
p.sub.19=p.sub.19⊕λ.sub.0p.sub.585=p.sub.585⊕λ.sub.0p.sub.710=p.sub.710⊕λ.sub.0p.sub.3241=p.sub.3241⊕λ.sub.0p.sub.3276=p.sub.3276⊕λ.sub.0 p.sub.3648=p.sub.3648⊕λ.sub.0p.sub.6345=p.sub.6345⊕λ.sub.0p.sub.9224=p.sub.9224⊕λ.sub.0p.sub.9890=p.sub.9890⊕λ.sub.0p.sub.10841=p.sub.10841⊕λ.sub.0
where the addition ⊕ occurs in GF(2).
(69) The subsequent L−1 information bits, that is, λ.sub.m, m=1, 2, . . . , L−1, are accumulated at parity bit addresses that are calculated by the following Equation 5:
(x+m×Q.sub.1)mod M.sub.1 if x<M.sub.1
M.sub.1+{(x−M.sub.1+m×Q.sub.2)mod M.sub.2} if x≧M.sub.1 (5)
where x denotes the addresses of parity bits corresponding to the first information bit λ.sub.0, that is, the addresses of the parity bits specified in the first row of the sequence of the Sequence Table, Q.sub.1=M.sub.1/L, Q.sub.2=M.sub.2/L, and L=360. Furthermore, Q.sub.1 and Q.sub.2 are defined in the following Table 2. For example, for an LDPC code having a length of 16200 and a code rate of 4/15, M.sub.1=1080, Q.sub.1=3, M.sub.2=10800, Q.sub.2=30 and L=360, and the following operations are performed on the second bit λ1 using Equation 5:
p.sub.22=p.sub.22⊕λ.sub.1 p.sub.588=p.sub.588⊕λ.sub.1 p.sub.713=p.sub.713⊕λ.sub.1 p.sub.3271=p.sub.3271⊕λ.sub.1 p.sub.3306=p.sub.3306⊕λ.sub.1 p.sub.3678=p.sub.3678⊕λ.sub.1 p.sub.6375=p.sub.6375⊕λ.sub.1 p.sub.9254=p.sub.9254⊕λ.sub.1 p.sub.9920=p.sub.9920⊕λ.sub.1 p.sub.108=p.sub.10871⊕λ.sub.1
(70) Table 2 illustrates the sizes of M.sub.1, Q.sub.1, M.sub.2 and Q.sub.2 of the designed QC-LDPC code:
(71) TABLE-US-00004 TABLE 2 Sizes Code rate Length M.sub.1 M.sub.2 Q.sub.1 Q.sub.2 4/15 16200 1080 10800 3 30
(72) The addresses of parity bit accumulators for new 360 information bits from λ.sub.L to λ.sub.2L−1 are calculated and accumulated from Equation 5 using the second row of the sequence.
(73) In a similar manner, for all groups composed of new L information bits, the addresses of parity bit accumulators are calculated and accumulated from Equation 5 using new rows of the sequence.
(74) After all the information bits from λ.sub.0 to λ.sub.−1 have been exhausted, the operations of the following Equation 6 are sequentially performed from i=1:
p.sub.i=p.sub.i⊕p.sub.i−1 for i=0,1, . . . ,M.sub.1−1 (6)
(75) Thereafter, when a parity interleaving operation, such as that of the following Equation 7, is performed, parity bits corresponding to the dual diagonal matrix B are generated:
λ.sub.K+L.Math.1+s=p.sub.Q.sub.
(76) When the parity bits corresponding to the dual diagonal matrix B have been generated using K information bits, λ.sub.0, λ.sub.1, . . . , λ.sub.K−1, parity bits corresponding to the identity matrix D are generated using the M.sub.1 generated parity bits λ.sub.K, λ.sub.K+1, . . . , λ.sub.K+M.sub.
(77) For all groups composed of L information bits from λ.sub.K to λ.sub.K+M.sub.
(78) When a parity interleaving operation, such as that of the following Equation 8, is performed after all the information bits from λ.sub.K to λ.sub.K+M.sub.
λ.sub.K+M.sub.
(79)
(80) Referring to
(81) In this case, 360 may be the parallel factor (PF) of the LDPC codeword. That is, since the PF is 360, the LDPC codeword having a length of 64800 is divided into 180 bit groups, as illustrated in
(82)
(83) Referring to
(84) In this case, 360 may be the parallel factor (PF) of the LDPC codeword. That is, since the PF is 360, the LDPC codeword having a length of 16200 is divided into 45 bit groups, as illustrated in
(85)
(86) Referring to
(87) For example, it is assumed that an interleaving sequence for an LDPC codeword having a length of 16200 is as follows:
interleaving sequence={24 34 15 11 2 28 17 25 5 38 19 13 6 39 1 14 33 37 29 12 42 31 30 32 36 40 26 35 44 4 16 8 20 43 21 7 0 18 23 3 10 41 9 27 22}
(88) Then, the order of the bit groups of the LDPC codeword illustrated in
(89) That is, it can be seen that each of the LDPC codeword 610 and the interleaved codeword 620 includes 45 bit groups, and it can be also seen that, by the interleaving sequence, the 24th bit group of the LDPC codeword 610 is changed into the 0th bit group of the interleaved LDPC codeword 620, the 34th bit group of the LDPC codeword 610 is changed into the 1st bit group of the interleaved LDPC codeword 620, the 15th bit group of the LDPC codeword 610 is changed into the 2nd bit group of the interleaved LDPC codeword 620, and the list bit group of the LDPC codeword 610 is changed into the 3rd bit group of the interleaved LDPC codeword 620, and the 2nd bit group of the LDPC codeword 610 is changed into the 4th bit group of the interleaved LDPC codeword 620.
(90) An LDPC codeword (u.sub.0, u.sub.1, . . . , u.sub.N.sub.
X.sub.j={u.sub.k|360×j≦k<360×(j+1),0≦k<N.sub.ldpc} for 0≦j<N.sub.group (9)
where X.sub.j is an j-th bit group, and each X.sub.j is composed of 360 bits.
(91) The LDPC codeword divided into the bit groups is interleaved, as in Equation 10 below:
Y.sub.j=X.sub.π(j) 0≦j≦N.sub.group (10)
where Y.sub.j is an interleaved j-th bit group, and π(j) is a permutation order for bit group-based interleaving (bit group-unit interleaving). The permutation order corresponds to the interleaving sequence of Equation 11 below:
interleaving sequence={34 3 19 35 25 2 17 36 26 38 0 40 27 10 7 43 21 28 15 6 1 37 18 30 32 33 29 22 12 13 5 23 44 14 4 31 20 39 42 11 9 16 41 8 24} (11)
(92) That is, when each of the codeword and the interleaved codeword includes 45 bit groups ranging from a 0th bit group to a 44th bit group, the interleaving sequence of Equation 11 means that the 34th bit group of the codeword becomes the 0th bit group of the interleaved codeword, the 3th bit group of the codeword becomes the 1st bit group of the interleaved codeword, the 19th bit group of the codeword becomes the 2nd bit group of the interleaved codeword, the 35th bit group of the codeword becomes the 3rd bit group of the interleaved codeword, . . . , the 8th bit group of the codeword becomes the 43th bit group of the interleaved codeword, and the 24th bit group of the codeword becomes the 44th bit group of the interleaved codeword.
(93) In particular, the interleaving sequence of Equation 11 has been optimized for a case where 16-symbol mapping (NUC symbol mapping) is employed and an LDPC coder having a length of 16200 and a code rate of 4/15 is used.
(94) In general, broadcasting and communication systems use uniform quadrature amplitude modulation (QAM) in order to transmit error correction coded data.
(95)
(96) Referring to
(97) Although gray mapping is used for bit stream mapping between symbols in
(98) In the uniform 16-QAM signal constellation illustrated in
(99) Symmetric design technology may be used for the design of a non-uniform signal constellation.
(100) That is, in the case of 16-QAM, after the four signal constellation symbols of a 1st quadrant have been designed first, the signal constellation symbols of the remaining three quadrants may be symmetrically designed.
(101) For example, when the vector of the four signal constellation symbols of the 1st quadrant is w=(w.sub.0, w.sub.1, w.sub.2, w.sub.3), the vectors of the signal constellation symbols of the remaining quadrants may be determined, as follows:
(102) 1st quadrant: (w.sub.0, w.sub.1, w.sub.2, w.sub.3)=w
(103) 2nd quadrant: (w.sub.4, w.sub.5, w.sub.6, w.sub.7)=−conj(w)
(104) 3rd quadrant: (w.sub.12, w.sub.13, w.sub.14, w.sub.15)=−w
(105) 4th quadrant: (w.sub.8, w.sub.9, w.sub.10, w.sub.11)=conj(w)
(106) In this case, conj(w) may be a function that outputs the conjugate complex numbers of all the elements of w.
(107) It will be apparent that the vectors of signal constellation symbols may be determined using other various methods.
(108) A symbol w.sub.1 may have a bit stream mapping value corresponding to a decimal value i. For example, w.sub.3=3.sub.(10)=0010.sub.(2).
(109) If symmetric design technology is used when a non-uniform signal constellation is designed, the advantage of considerably reducing complexity is achieved.
(110) In order to further reduce design complexity, it may be assumed that the amplitudes of the real and imaginary components of the vector w corresponding to four signal constellation symbols of the 1st quadrant are symmetric. That is, the amplitudes of the real and imaginary components of two of the four symbols of the 1st quadrant may be symmetric.
(111) In this case, four pulse amplitude modulation (PAM) points rather than four complex numbers are designed. In this case, after the smallest PAM value has been set to 1 and the remaining three PAM values have been found, power may be normalized. As a result, based on the above-mentioned symmetry, when three PAM values are designed, a total of 16 signal constellations may be generated.
(112) In general, in order to design L=M.sup.2 signal constellations, it is sufficient if (M−1) PAM values are designed.
(113) When (M−1) PAM values are obtained, the result obtained by the power normalization of the obtained (M−1) PAM values and the smallest PAM value is defined as PAM_norm=[P.sub.1 P.sub.2 . . . P.sub.M]. When w is obtained using PAM_norm, the following expressions may be obtained based on the assumption that real and imaginary PAM values are symmetric:
|real(w.sub.0)|=|imaginary(w.sub.1)|
|real(w.sub.1)|=|imaginary(w.sub.0)|
|real(w.sub.2)|=|imaginary(w.sub.3)|
|real(w.sub.3)|=|imaginary(w.sub.2)|
where real(i) is a function that outputs the real component of i, imaginary(i) is a function that outputs the imaginary component of i, and i is an arbitrary complex number.
(114) That is, when the real number values of the vector w corresponding to 1st quadrant symbols are defined, all the imaginary number values of w are defined accordingly. In the case of 16-QAM in which there are a total of four symbols in its 1st quadrant, a total of 4! (factorial)=4×3×2×1=24 combinational methods, as shown in Table 3 below. Table 3 below lists 24 methods of obtaining the vector w corresponding to the 1st quadrant symbols:
(115) TABLE-US-00005 TABLE 3 Imag- Imag- Imag- Imag- Real inary Real inary Real inary Real inary Method of w.sub.0 of w.sub.0 of w.sub.1 of w.sub.1 of w.sub.2 of w.sub.2 of w.sub.3 of w.sub.3 1 P.sub.1 P.sub.2 P.sub.2 P.sub.1 P.sub.3 P.sub.4 P.sub.4 P.sub.3 2 P.sub.1 P.sub.2 P.sub.2 P.sub.1 P.sub.4 P.sub.3 P.sub.3 P.sub.4 3 P.sub.1 P.sub.3 P.sub.3 P.sub.1 P.sub.2 P.sub.4 P.sub.4 P.sub.2 4 P.sub.1 P.sub.3 P.sub.3 P.sub.1 P.sub.4 P.sub.2 P.sub.2 P.sub.4 5 P.sub.1 P.sub.4 P.sub.4 P.sub.1 P.sub.2 P.sub.3 P.sub.3 P.sub.2 6 P.sub.1 P.sub.4 P.sub.4 P.sub.1 P.sub.3 P.sub.2 P.sub.2 P.sub.3 7 P.sub.2 P.sub.1 P.sub.1 P.sub.2 P.sub.3 P.sub.4 P.sub.4 P.sub.3 8 P.sub.2 P.sub.1 P.sub.1 P.sub.2 P.sub.4 P.sub.3 P.sub.3 P.sub.4 9 P.sub.2 P.sub.3 P.sub.3 P.sub.2 P.sub.1 P.sub.4 P.sub.4 P.sub.1 10 P.sub.2 P.sub.3 P.sub.3 P.sub.2 P.sub.4 P.sub.1 P.sub.1 P.sub.4 11 P.sub.2 P.sub.4 P.sub.4 P.sub.2 P.sub.1 P.sub.3 P.sub.3 P.sub.1 12 P.sub.2 P.sub.4 P.sub.4 P.sub.2 P.sub.3 P.sub.1 P.sub.1 P.sub.3 13 P.sub.3 P.sub.1 P.sub.1 P.sub.3 P.sub.2 P.sub.4 P.sub.4 P.sub.2 14 P.sub.3 P.sub.1 P.sub.1 P.sub.3 P.sub.4 P.sub.2 P.sub.2 P.sub.4 15 P.sub.3 P.sub.2 P.sub.2 P.sub.3 P.sub.1 P.sub.4 P.sub.4 P.sub.1 16 P.sub.3 P.sub.2 P.sub.2 P.sub.3 P.sub.4 P.sub.1 P.sub.1 P.sub.4 17 P.sub.3 P.sub.4 P.sub.4 P.sub.3 P.sub.1 P.sub.2 P.sub.2 P.sub.1 18 P.sub.3 P.sub.4 P.sub.4 P.sub.3 P.sub.2 P.sub.1 P.sub.1 P.sub.2 19 P.sub.4 P.sub.1 P.sub.1 P.sub.4 P.sub.2 P.sub.3 P.sub.3 P.sub.2 20 P.sub.4 P.sub.1 P.sub.1 P.sub.4 P.sub.3 P.sub.2 P.sub.2 P.sub.3 21 P.sub.4 P.sub.2 P.sub.2 P.sub.4 P.sub.1 P.sub.3 P.sub.3 P.sub.1 22 P.sub.4 P.sub.2 P.sub.2 P.sub.4 P.sub.3 P.sub.1 P.sub.1 P.sub.3 23 P.sub.4 P.sub.3 P.sub.3 P.sub.4 P.sub.1 P.sub.2 P.sub.2 P.sub.1 24 P.sub.4 P.sub.3 P.sub.3 P.sub.4 P.sub.2 P.sub.1 P.sub.1 P.sub.2
(116) For example, an optimum PAM_norm value designed for an LDPC code having a code rate of 4/15 may be [0.3412 0.5241 0.5797 1.1282].
(117) In this case, when the obtained PAM_norm is converted into the vector w corresponding to the 1st quadrant symbols using method 1 of Table 3, w=[0.3412+0.5241i 0.5241+0.3412i 0.5797+1.1282i 1.1282+0.5797i] can be obtained.
(118) Table 4 below lists the 16 symbols of a non-uniform 16-symbol signal constellation optimized for an LDPC code having a code rate of 4/15. In general, since an error correction code has a varying operating SNR and error correction capability depending on the code rate, the performance of BICM can be maximized only when the value of the vector w optimized for each code rate is used. If a non-uniform signal constellation optimized for a specific code rate is used at a different code rate, the performance of BICM can be considerably reduced, and thus it is important to use a non-uniform signal constellation suitable for the code rate of an LDPC code:
(119) TABLE-US-00006 TABLE 4 W Constellation 0 0.3412 + 0.5241i 1 0.5241 + 0.3412i 2 0.5797 + 1.1282i 3 1.1282 + 0.5797i 4 −0.3412 + 0.5241i 5 −0.5241 + 0.3412i 6 −0.5797 + 1.1282i 7 −1.1282 + 0.5797i 8 0.3412 − 0.5241i 9 0.5241 − 0.3412i 10 0.5797 − 1.1282i 11 1.1282 − 0.5797i 12 −0.3412 − 0.5241i 13 −0.5241 − 0.3412i 14 −0.5797 − 1.1282i 15 −1.1282 − 0.5797i
(120)
(121) Referring to
(122)
(123)
(124) Referring to
(125)
(126) Referring to
(127) The memory 1010 receives a codeword corresponding to an LDPC code having a code rate of 4/15.
(128) In this case, the codeword may be an error correction coded LDPC codeword, and may be an LDPC codeword interleaved codeword.
(129) The processor 1020 maps codewords to the 16 symbols of a non-uniform 16-symbol signal constellation on a 4-bit basis.
(130) In this case, the processor 1020 may adjust any one of the amplitude and phase of a carrier corresponding to symbol mapping.
(131) In this case, the 16 symbols have non-uniform distances therebetween, and may include a first group of four symbols of a 1st quadrant, a second group of four symbols symmetric to the four symbols of the first group with respect to an imaginary axis, a third group of four symbols symmetric to the four symbols of the first group with respect to an origin, and a fourth group of four symbols symmetric to the four symbols of the first group with respect to a real axis.
(132) In this case, if a vector corresponding to the four symbols w.sub.0, w.sub.1, w.sub.2 and w.sub.3 of the first group is w, a vector corresponding to the four symbols w.sub.4, w.sub.5, w.sub.6 and w.sub.7 of the second group may be −conj(w) (conj(w) is a function that outputs the conjugate complex numbers of all the elements of w), a vector corresponding to the four symbols w.sub.12, w.sub.13, w.sub.14 and w.sub.15 of the third group may be −w, and a vector corresponding to the four symbols w.sub.8, w.sub.9, w.sub.10 and w.sub.11 of the fourth group may be conj(w).
(133) In this case, the amplitudes of the real and imaginary components of two of the four symbols of the first group may be symmetric.
(134) In this case, the four symbols of the first group are w.sub.0, w.sub.1, w.sub.2 and w.sub.3, |real(w.sub.0)|=|imaginary(w.sub.1)| (real(i) is a function that outputs the real component of i, imaginary(i) is a function that outputs the imaginary component of i, and i is an arbitrary complex number), |real (w.sub.1)|=|imaginary(w.sub.0)|, |real(w.sub.2)|=|imaginary(w.sub.3)|, and |real(w.sub.3)|=|imaginary(w.sub.2)|.
(135) In this case, the 16 symbols may be defined as listed in the above Table 4.
(136) The memory 1030 may store additional information required for the operation of the processor 1020. For example, the memory 1030 may store information about a carrier frequency, an amplitude, etc.
(137) The memory 1010 and the memory 1030 may correspond to various pieces of hardware for storing a set of bits, and may correspond to data structures, such as an array, a list, a stack, a queue and the like.
(138) In this case, the memory 1010 and the memory 1030 may not be separate physical devices, but may correspond to different addresses of a single physical device. That is, the memory 1010 and the memory 1030 may not be physically distinguished from each other, and may be only logically distinguished from each other.
(139)
(140) Referring to
(141) In this case, the codeword may be an error correction coded LDPC codeword or an LDPC codeword interleaved codeword. That is, at step S1110, the codeword may be received directly from an LDPC coder, or the codeword may be received by way of a bit interleaver.
(142) Furthermore, in the modulation method using a 16-symbol non-uniform signal constellation according to the present embodiment, the codeword is mapped to the 16 symbols of the non-uniform 16-symbol signal constellation on a 4-bit basis at step S1120.
(143) In this case, the 16 symbols have non-uniform distances therebetween, and may include a first group of four symbols of a 1st quadrant, a second group of four symbols symmetric to the four symbols of the first group with respect to an imaginary axis, a third group of four symbols symmetric to the four symbols of the first group with respect to an origin, and a fourth group of four symbols symmetric to the four symbols of the first group with respect to a real axis.
(144) In this case, a vector corresponding to the four symbols w.sub.0, w.sub.1, w.sub.2 and w.sub.3 of the first group may be w, a vector corresponding to the four symbols w.sub.4, w.sub.5, w.sub.6 and w.sub.7 of the second group may be −conj(w) (conj(w) is a function that outputs the conjugate complex numbers of all the elements of w), a vector corresponding to the four symbols w.sub.12, w.sub.13, w.sub.14 and w.sub.15 of the third group may be −w, and a vector corresponding to the four symbols w.sub.8, w.sub.9, w.sub.10 and w.sub.11 of the fourth group may be conj(w).
(145) In this case, the amplitudes of the real and imaginary components of two of the four symbols of the first group may be symmetric.
(146) In this case, the four symbols of the first group are w.sub.0, w.sub.1, w.sub.2 and w.sub.3, |real(w.sub.0)|=|imaginary(w.sub.1)| (real(i) is a function that outputs the real component of i, imaginary(i) is a function that outputs the imaginary component of i, and i is an arbitrary complex number), |real(w.sub.1)|=|imaginary(w.sub.0)|, |real(w.sub.2)|=|imaginary(w.sub.3)|, and |real(w.sub.3)|=|imaginary(w.sub.2)|.
(147) In this case, the 16 symbols may be defined as listed in the above Table 4.
(148) Furthermore, in the modulation method using a 16-symbol non-uniform signal constellation according to the present embodiment, any one or more of the amplitude and phase of a carrier are adjusted in accordance with the mapping at step S1130.
(149) The error correction coder 13 illustrated in
(150) That is, the error-correction coder may include memories and a processor. In this case, the first memory is a memory that stores an LDPC codeword having a length of 16200 and a code rate of 4/15, and a second memory is a memory that is initialized to 0.
(151) The memories may correspond to λ.sub.i (i=0, 1, . . . , N−1) and P.sub.j (j=0, 1, . . . , M.sub.1+M.sub.2−1), respectively.
(152) The processor may generate an LDPC codeword corresponding to information bits by performing accumulation with respect to the memory using a sequence corresponding to a parity check matrix (PCM).
(153) In this case, the accumulation may be performed at parity bit addresses that are updated using the sequence of the above Sequence Table.
(154) In this case, the LDPC codeword may include a systematic part λ.sub.0, λ.sub.1, . . . , λ.sub.k−1 corresponding to the information bits and having a length of 4320 (=K), a first parity part λ.sub.K, λ.sub.K+1, . . . , λ.sub.K+M.sub.
(155) In this case, the sequence may have a number of rows equal to the sum (4320/360+1080/360=15) of a value obtained by dividing the length of the systematic part, that is, 4320, by a CPM size L corresponding to the PCM, that is, 360, and a value obtained by dividing the length M.sub.1 of the first parity part, that is, 1080, by 360.
(156) As described above, the sequence may be represented by the above Sequence Table.
(157) In this case, the second memory may have a size corresponding to the sum M.sub.1+M.sub.2 of the length M.sub.1 of the first parity part and the length M.sub.2 of the second parity part.
(158) In this case, the parity bit addresses may be updated based on the results of comparing each x of the previous parity bit addresses, specified in respective rows of the sequence, with the length M.sub.1 of the first parity part.
(159) That is, the parity bit addresses may be updated using Equation 5. In this case, x may be the previous parity bit addresses, m may be an information bit index that is an integer larger than 0 and smaller than L, L may be the CPM size of the PCM, Q.sub.1 may be M.sub.1/L, M.sub.1 may be the size of the first parity part, Q.sub.2 may be M.sub.2/L, and M.sub.2 may be the size of the second parity part.
(160) In this case, it may be possible to perform the accumulation while repeatedly changing the rows of the sequence by the CPM size L (=360) of the PCM, as described above.
(161) In this case, the first parity part λ.sub.K, λ.sub.K+1, . . . , λ.sub.K+M.sub.
(162) In this case, the second parity part λ.sub.K+M.sub.
(163) The bit interleaver 14 illustrated in
(164) That is, the first memory may store an LDPC codeword having a length of 16200 and a code rate of 4/15. The processor may generate an interleaved codeword by interleaving the LDPC codeword on a bit group basis, in which the bit group corresponds to the parallel factor of the LDPC codeword. In this case, the parallel factor may be 360. In this case, the bit group may include 360 bits. In this case, the LDPC codeword may be divided into 45 bit groups, as represented by Equation 9.
(165) In this case, the interleaving may be performed using Equation 10 using permutation order.
(166) In this case, the permutation order may correspond to the interleaving sequence represented by Equation 11.
(167) The second memory provides the interleaved codeword to the modulator for 16-symbol mapping.
(168) In this case, the modulator may be a symbol mapping device for non-uniform constellation (NUC) symbol mapping, as described in conjunction with
(169) In accordance with at least one embodiment of the present invention, a signal constellation signal constellation for the transmission of error correction coded data in a next-generation broadcast system is intentionally distorted, thereby achieving considerably improved performance compared to a uniform signal constellation.
(170) In accordance with at least one embodiment of the present invention, a non-uniform 16-symbol signal constellation is optimized for an LDPC coder having a code rate of 4/15 and thus can be applied to next-generation broadcast systems, such as ATSC 3.0.
(171) Although the specific embodiments of the present invention have been disclosed for illustrative purposes, those skilled in the art will appreciate that various modifications, additions and substitutions are possible without departing from the scope and spirit of the invention as disclosed in the accompanying claims.