Method and apparatus for decoding low density parity check code

Information

  • Patent Grant
  • 8910011
  • Patent Number
    8,910,011
  • Date Filed
    Wednesday, March 21, 2012
    12 years ago
  • Date Issued
    Tuesday, December 9, 2014
    10 years ago
Abstract
A low-density parity check (LDPC) code decoding method may be provided. The LDPC code decoding method may linearize or perform step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code, and may convert the linearized function to correspond to a check node updating equation of a min-sum algorithm.
Description
CROSS-REFERENCE TO RELATED APPLICATION

This application claims the benefit of Korean Patent Application No. 10-2011-0044560, filed on May 12, 2011, in the Korean Intellectual Property Office, the disclosure of which is incorporated herein by reference.


BACKGROUND

1. Field of the Invention


The present invention relates to a method and apparatus for improving a performance of decoding a low-density parity check (LDPC) code, which is one form of a forward error correction (FEC) coding scheme.


2. Description of the Related Art


In general, a sum-product algorithm, a minimum-sum (min-sum) algorithm, an offset min-sum algorithm, a normalized min-sum algorithm, and the like are utilized to decode a low-density parity check (LDPC) code.


The LDPC code may be expressed by a Tanner graph including a variable node and a check node, and may be decoded through iterative decoding, that is, iterative information transfer by the check node and variable node, in the Tanner graph.


The sum-product algorithm to be used for decoding the LDPC code may be expressed as described in the following.


In a variable node having two inputs, an information updating process may be expressed by L(r)=L(u)+L(v).


In a check node having two inputs, an information updating process may be expressed by







tanh


(


L


(
r
)


2

)


=


tanh


[


L


(
u
)


2

]


·

tanh


[


L


(
v
)


2

]















L


(
r
)



=



2






tanh

-
1




{


tanh


[


L


(
u
)


2

]


·

tanh


[


L


(
v
)


2

]



}








=




ln






cosh


(



L


(
u
)


+

L


(
v
)



2

)



-

ln







cosh


(



L


(
u
)


-

L


(
v
)



2

)


.










In this example, L(u) and L(v) denote input information associated with each node, and L(r) denotes output information of each node.


In a Binary Input-Additive White Gaussian Noise Channel (BI-AWGNC), L(m) may be expressed by







L


(
m
)


=


2

σ
2




m
.






In this example, σ2 denotes a variance of a channel noise.


As described in the foregoing, the sum-product algorithm may be expressed by a sum of input information in the variable node, and may be expressed by a product of hyperbolic tangent functions of input information, that is, a product of ‘tan h( )’ functions, in a check node.


To decode the LDPC code through use of the sum-product algorithm, estimation of σ2, that is a variance of a channel noise, and calculation of a complex ‘tan h( )’ function or ‘ln(cos h( ))’ function may need to be performed.


To avoid the calculation of a complex function and the estimation of a variable of a channel noise, the min-sum algorithm has been proposed.


The min-sum algorithm for decoding the LDPC code may be expressed as described in the following.


In a variable node having two inputs, an information updating process may be expressed by r=u+v.


In a check node having two inputs, an information updating process may be expressed by r=sign(u)sign(v)min (|u|,|v|).


In this example, sign( ) denotes a sign of an input value.


The min-sum algorithm may be expressed by a sum of input information in the variable node, and may be expressed by a minimum value multiplied by signs of input information in the check node.


Although the sum-product algorithm may provide an excellent performance, the sum-product algorithm may have a significantly high complexity and may need to estimate a variance of a channel noise. Conversely, the min-sum algorithm may have a significantly low complexity and may not need to estimate a variance of a channel noise, but may provide a relatively low performance.


To improve deterioration of a performance caused while using the min-sum algorithm, either the normalized min-sum algorithm or the offset min-sum algorithm is generally utilized.


The normalized min-sum algorithm conventionally used for decoding the LDPC code may be expressed by r=u+v, r=α·sign(u)sign(v)min(|u|,|v|).


In this example, α(<1) denotes a constant for normalizing a check node, and may be appropriately selected based on a used LDPC code.


The offset min-sum algorithm conventionally used for decoding the LDPC code may be expressed by r=u+v, r=sign(u)sign(v)max(min(|u|,|v|)−β, 0).


In this example, β denotes an offset value of a check node, and may be appropriately selected based on an LDPC code to be used.


Although the normalized min-sum algorithm and the offset min-sum algorithm may provide a superior performance for a regular LDPC code, the performance may be deteriorated for an irregular LDPC code.


SUMMARY

According to an aspect of the present invention, there is provided a low-density parity check (LDPC) code decoding method, the method including linearizing a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code, and converting the linearized function to correspond to a check node updating equation of a minimum-sum (min-sum) algorithm.


According to another aspect of the present invention, there is provided an LDPC code decoding method, the method including performing step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code, and converting the step-approximated function to correspond to a check node updating equation of a min-sum algorithm.


According to still another aspect of the present invention, there is provided an LDPC code decoding apparatus, the apparatus including a first operation unit to linearize a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code, and a second operation unit to convert the linearized function to correspond to a check node updating equation of a min-sum algorithm.


According to yet another aspect of the present invention, there is provided an LDPC code decoding apparatus, the apparatus including a first operation unit to perform step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code, and a second operation unit to convert the step-approximated function to correspond to a check node updating equation of a min-sum algorithm.


Additional aspects, features, and/or advantages of the invention will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the invention.





BRIEF DESCRIPTION OF THE DRAWINGS

These and/or other aspects, features, and advantages of the invention will become apparent and more readily appreciated from the following description of embodiments, taken in conjunction with the accompanying drawings of which:



FIG. 1 is a block diagram illustrating a configuration of a decoding apparatus of a low-density parity check (LDPC) code according to an embodiment of the present invention;



FIG. 2 is a diagram illustrating a variable node according to an embodiment of the present invention;



FIG. 3 is a diagram illustrating a check node according to an embodiment of the present invention;



FIG. 4 is a flowchart illustrating an LDPC code decoding method according to an embodiment of the present invention;



FIG. 5 is a diagram illustrating a linearization graph according to an embodiment of the present invention;



FIG. 6 is a flowchart illustrating an LDPC code decoding method according to another embodiment of the present invention;



FIG. 7 is a diagram illustrating a step-approximation graph according to an embodiment of the present invention; and



FIG. 8 is a diagram illustrating various examples of an LDPC code decoding algorithm and a bit error rate (BER) performance according to an embodiment of the present invention.





DETAILED DESCRIPTION

Reference will now be made in detail to embodiments of the present invention, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout. Embodiments are described below to explain the present invention by referring to the figures.



FIG. 1 illustrates a configuration of a low-density parity check (LDPC) code decoding apparatus 100 of according to an embodiment of the present invention.


Referring to FIG. 1, the LDPC code decoding apparatus 100 may include a first operation unit 110 to linearize or to perform step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code, and may include a second operation unit 120 to convert the linearized function to correspond to a check node updating equation of a min-sum algorithm.


Also, the LDPC code decoding apparatus 100 may additionally include a third operation unit 130 to calculate a variable node updating equation to be used for decoding the LDPC code, according to a predetermined operation expression.


The LDPC code decoding apparatus 100 may receive channel information and a signal including an LDPC code received from at least one channel through the receiving unit 140, and may apply an algorithm for decoding the LDPC code through operation units 110, 120, and 130.


The LDPC code decoding apparatus 100 may additionally include a storage unit 150 to store data, for example, channel information, a signal including an LDPC code, and the like received through the receiving unit 140, and may also store data calculated through the operation units 110, 120, and 130 in the storage unit 150 and may manage the stored data.



FIG. 2 illustrates a variable node according to an embodiment of the present invention. FIG. 3 illustrates a check node according to an embodiment of the present invention.


Exemplary embodiments may describe that an LDPC code is decoded through iterative information transfer by a check node and a variable node, as illustrated in FIGS. 2 and 3.


An LDPC code decoding method performed through use of the LDPC code decoding apparatus 100 will be described.


Among LDPC code decoding methods that convert a sum-product algorithm into a min-sum algorithm so as to decode an LDPC code received through the receiving unit 140, a linearization updating method will be described.



FIG. 4 illustrates an LDPC code decoding method according to an embodiment of the present invention.


The first operation unit 110 may linearize a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code in operation 410.


The natural logarithm hyperbolic cosine function may be expressed by Equation 1.










ln






cosh


(
x
)



=

{





a
·


x



,






x



A









x


-

log





2


,






x


>
A









[

Equation





1

]







In Equation 1, a denotes a slope of the check node updating equation, and A is








log





2


1
-
a


.




The first operation unit 110 may apply the check node updating equation to which the linearized function is applied, according to Equation 2.











[

Equation





2

]








L


(
r
)


=



ln






cosh


(



L


(
u
)


+

L


(
v
)



2

)



-

ln






cosh


(



L


(
u
)


-

L


(
v
)



2

)






{






a






L


(
u
)


+

L


(
v
)



2




-

a






L


(
u
)


-

L


(
v
)



2





,












L


(
u
)


+

L


(
v
)







2

A


,










L


(
u
)


-

L


(
v
)







2

A
















L


(
u
)


+

L


(
v
)



2



-

log





2

-

a






L


(
u
)


-

L


(
v
)



2





,












L


(
u
)


+

L


(
v
)





>

2

A


,










L


(
u
)


-

L


(
v
)







2

A












a






L


(
u
)


+

L


(
v
)



2




-





L


(
u
)


-

L


(
v
)



2



+

log





2


,












L


(
u
)


+

L


(
v
)







2

A


,










L


(
u
)


-

L


(
v
)





>

2

A












sign


(

L


(
u
)


)




sign


(

L


(
v
)


)




min


(




L


(
u
)




,



L


(
v
)





)



,












L


(
u
)


+

L


(
v
)





>

2

A


,










L


(
u
)


-

L


(
v
)





>

2

A














In this example, L(u) and L(v) denote input information of a check node, and L(r) denotes output information of the check node.



FIG. 5 illustrates a linearization graph according to an embodiment of the present invention.


When a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm is linearized by the first operation unit 110, Equation 5 may be obtained.


The check node updating performed through linearization of the converted function may use L(m) including noise information of a channel and thus, an approximated check node may be modified so as to remove a process of estimating a variance of a channel noise.


That is, the second operation unit 120 may convert the linearized function to correspond to a check node updating equation of a min-sum algorithm in operation 420.


The second operation unit 120 may apply the check node updating equation to which the function converted to correspond to the check node updating equation of the min-sum algorithm is applied, according to Equation 3.











[

Equation





3

]








L


(
r
)


=

{






a
·

sign


(
u
)





sign


(
v
)




min


(



u


,


v



)



,








u
+
v






σ
op
2

·
A


,




u
-
v






σ
op
2

·
A











sign


(
u
)




sign


(
v
)




min


(



u


,


v



)



-

C
offset


,








u
+
v






σ
op
2

·
A


,




u
-
v






σ
op
2

·
A











sign


(
u
)




sign


(
v
)




min


(



u


,


v



)



+

C
offset


,








u
+
v






σ
op
2

·
A


,




u
-
v






σ
op
2

·
A










sign


(
u
)




sign


(
v
)




min


(



u


,


v



)



,








u
+
v






σ
op
2

·
A


,




u
-
v






σ
op
2

·
A











In Equation 3, Coffset denotes








σ
op
2

·

(


log





2

4

)


,





and σop2 denotes a channel noise variance at an operating point of a check node.


σop2 may be appropriately selected based on a used LDPC code, like a normalization constant of a normalized min-sum algorithm or an offset value of an offset min-sum algorithm.


σop2 may be different based on a code, and may not be changed after an initial setting.


The third operation unit 130 may calculate a variable node updating equation to be used for decoding the LDPC code, as expressed by Equation 4 in operation 430.

r=u+v  [Equation 4]


In this example, u and v denotes input information of a variable node, and r denotes output information of the variable node.


Among LDPC code decoding methods that convert a sum-product algorithm into a min-sum algorithm to process decoding, a step-approximation updating method will be described.



FIG. 6 illustrates an LDPC code decoding method according to another embodiment of the present invention.


Referring to FIG. 6, the first operation unit 110 may perform step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code in operation 610.


The natural logarithm hyperbolic cosine function may be expressed by Equation 5.










ln






cosh


(
x
)



=

{




b
,






x



B









x


-

log





2


,






x


>
B









[

Equation





5

]







In Equation 5, b denotes a step value of the check node updating equation, and B is log 2+b.


The first operation unit 110 may apply the check node updating equation to which the step-approximated function is applied, according to Equation 6.











[

Equation





6

]








L


(
r
)


=



ln






cosh


(



L


(
u
)


+

L


(
v
)



2

)



-

ln






cosh


(



L


(
u
)


-

L


(
v
)



2

)






{




0
,












L


(
u
)


+

L


(
v
)







2

B


,










L


(
u
)


-

L


(
v
)







2

B
















L


(
u
)


+

L


(
v
)



2



-

log





2

-
b

,












L


(
u
)


+

L


(
v
)





>

2

B


,










L


(
u
)


-

L


(
v
)







2

B











b
-





L


(
u
)


-

L


(
v
)



2



+

log





2


,












L


(
u
)


+

L


(
v
)







2

B


,










L


(
u
)


-

L


(
v
)





>

2

B












sign


(

L


(
u
)


)




sign


(

L


(
v
)


)




min


(




L


(
u
)




,



L


(
v
)





)



,












L


(
u
)


+

L


(
v
)





>

2

B


,










L


(
u
)


-

L


(
v
)





>

2

B














In Equation 6, L(u) and L(v) denotes input information of a check node, and L(r) denotes output information of the check node.



FIG. 7 illustrates a step-approximation graph according to an embodiment of the present invention.


When a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm is linearized by the first operation unit 110, Equation 7 may be obtained.


The check node updating through step-approximation of the converted function may need to use L(m) including noise information of a channel and thus, an approximated check node may be modified to remove a process of estimating a variance of a channel noise.


The second operation unit 120 may convert the step-approximated function to correspond to a check node updating equation of a min-sum algorithm in operation 620.


The second operation unit 120 may apply the check node updating equation to which the function converted to correspond to the check node updating equation of the min-sum algorithm is applied, according to Equation 7.











[

Equation





7

]








L


(
r
)


=

{




0
,








u
+
v






σ
op
2

·
B


,




u
-
v






σ
op
2

·
B











sign


(
u
)




sign


(
v
)




min


(



u


,


v



)



-

C
offset


,








u
+
v






σ
op
2

·
B


,




u
-
v






σ
op
2

·
B











sign


(
u
)




sign


(
v
)




min


(



u


,


v



)



+

C
offset


,








u
+
v






σ
op
2

·
B


,




u
-
v






σ
op
2

·
B










sign


(
u
)




sign


(
v
)




min


(



u


,


v



)



,








u
+
v






σ
op
2

·
B


,




u
-
v






σ
op
2

·
B











In Equation 7, Coffset denotes








σ
op
2

·

(


b
+

log





2


4

)


,





and σop2 denotes a channel noise variance at an operating point of the check node.


σop2 may be appropriately selected based on a used LDPC code, like a normalization constant of a normalized min-sum algorithm or an offset value of an offset min-sum algorithm. Also, σop2 may be different based on a code, and may not be changed after an initial setting.


The third operation unit 130 may calculate a variable node updating equation to be used for decoding the LDPC code, as expressed by Equation 8, in operation 630.

r=u+v  [Equation 8]


In Equation 8, u and v denotes input information of a variable node, and r denotes output information of the variable node.



FIG. 8 illustrates various examples of an LDPC code decoding algorithm and a bit error rate (BER) performance according to an embodiment of the present invention.


Referring to FIG. 8, ‘Proposed Method 1’ corresponds to an LDPC code decoding through linearization and ‘Proposed Method 2’ corresponds to an LDPC code decoding through step-approximation.


For ease of description, a and b are assumed to be 0.5 and 0, respectively.


Also, it is assumed that σ(=1.0) at an operating point for ‘Proposed Method 1’ and σ(=1.14) at an operating point for ‘Proposed Method 2’ select a code rate of 0.4.


The LDPC code decoding apparatus 100 may provide an LDPC code decoding method through linearization or step approximation and thus, may provide a performance similar to a sum-product algorithm and superior than an offset min-sum algorithm.


The LDPC code decoding method may have a low complexity, and may provide a performance similar to a sum-product algorithm and thus, a reception performance of a communication and broadcasting system that uses an LDPC code may be improved.


The LDPC code decoding method may improve a performance of decoding an LDPC code, which is a form of an FEC coding scheme.


The LDPC code decoding method may improve a reception performance of a communication and broadcasting system that uses an LDPC code.


The LDPC code decoding method may have a low complexity and may provide a performance similar to a sum-product algorithm.


The method according to the above-described embodiments of the present invention may be recorded in non-transitory computer readable media including program instructions to implement various operations embodied by a computer. The media may also include, alone or in combination with the program instructions, data files, data structures, and the like. Examples of non-transitory computer readable media include magnetic media such as hard disks, floppy disks, and magnetic tape; optical media such as CD ROM discs and DVDs; magneto-optical media such as floptical discs; and hardware devices that are specially configured to store and perform program instructions, such as read-only memory (ROM), random access memory (RAM), flash memory, and the like. Examples of program instructions include both machine code, such as produced by a compiler, and files containing higher level code that may be executed by the computer using an interpreter. The described hardware devices may be configured to act as one or more software modules in order to perform the operations of the above-described embodiments of the present invention, or vice versa.


Although a few embodiments of the present invention have been shown and described, the present invention is not limited to the described embodiments. Instead, it would be appreciated by those skilled in the art that changes may be made to these embodiments without departing from the principles and spirit of the invention, the scope of which is defined by the claims and their equivalents.

Claims
  • 1. A method of decoding a low-density parity check (LDPC) code, the method comprising: linearizing a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code; andconverting the linearized function to correspond to a check node updating equation of a minimum-sum (min-sum) algorithm.
  • 2. The method of claim 1, wherein the natural logarithm hyperbolic cosine function is expressed by Equation 1:
  • 3. The method of claim 2, wherein the check node updating equation to which the linearized function is applied is expressed by Equation 2:
  • 4. The method of claim 3, wherein the check node updating equation to which the function converted to correspond to the check node updating equation of the min-sum algorithm is applied is expressed by Equation 3:
  • 5. The method of claim 1, further comprising: calculating a variable node updating equation to be used for decoding the LDPC code according to Equation 4: r=u+v,  [Equation 4]wherein u and v denote input information of a variable node, and r denotes output information of the variable node.
  • 6. A method of decoding a low-density parity check (LDPC) code, the method comprising: performing step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code; andconverting the step-approximated function to correspond to a check node updating equation of a minimum sum (min-sum) algorithm.
  • 7. The method of claim 6, wherein the natural logarithm hyperbolic cosine function is expressed by Equation 5:
  • 8. The method of claim 7, wherein the check node updating equation to which the step-approximated function is applied is expressed by Equation 6:
  • 9. The method of claim 8, wherein the check node updating equation to which the function converted to correspond to the check node updating equation of the min-sum algorithm is applied is expressed by Equation 7:
  • 10. The method of claim 6, further comprising: calculating a variable node updating equation to be used for decoding the LDPC code according to Equation 8: r=u+v,  [Equation 8]wherein u and v denote input information of a variable node, and r denotes output information of the variable node.
  • 11. An apparatus for decoding a low-density parity check (LDPC) code, the apparatus comprising: a first operation unit to linearize a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code; anda second operation unit to convert the linearized function to correspond to a check node updating equation of a minimum-sum (min-sum) algorithm.
  • 12. The apparatus of claim 11, wherein the natural logarithm hyperbolic cosine function is expressed by Equation 1:
  • 13. The apparatus of claim 12, wherein the check node updating equation to which the linearized function is applied is expressed by Equation 2:
  • 14. The apparatus of claim 13, wherein the check node updating equation to which the function converted to correspond to the check node updating equation of the min-sum algorithm is applied is expressed by Equation 3:
  • 15. The apparatus of claim 11, further comprising: a third operation unit to calculate a variable node updating equation to be used for decoding the LDPC code according to Equation 4: r=u+v,  [Equation 4]wherein u and v denote input information of a variable node, and r denotes output information of the variable node.
  • 16. An apparatus for decoding a low-density parity check (LDPC) code, the apparatus comprising: a first operation unit to perform step-approximation on a natural logarithm hyperbolic cosine function included in a check node updating equation of a sum-product algorithm used for decoding an LDPC code; anda second operation unit to convert the step-approximated function to correspond to a check node updating equation of a minimum-sum (min-sum) algorithm.
  • 17. The apparatus of claim 16, wherein the natural logarithm hyperbolic tangent function is expressed by Equation 5:
  • 18. The apparatus of claim 17, wherein the check node updating equation to which the step-approximated function is applied is expressed by Equation 6:
  • 19. The apparatus of claim 18, wherein the check node updating equation to which the function converted to correspond to the check node updating equation of the min-sum algorithm is applied is expressed by Equation 7:
  • 20. The apparatus of claim 16, further comprising: a third operation unit to calculate a variable node updating equation to be used for decoding the LDPC code according to Equation 8: r=u+v,  [Equation 8]wherein u and v denote input information of a variable node, and r denotes output information of the variable node.
Priority Claims (1)
Number Date Country Kind
10-2011-0044560 May 2011 KR national
US Referenced Citations (9)
Number Name Date Kind
6359878 Lakkis et al. Mar 2002 B1
6778615 Sweldens Aug 2004 B1
7032156 Yu et al. Apr 2006 B2
7055089 Miyauchi et al. May 2006 B2
7634703 Kutz et al. Dec 2009 B2
8578238 Priewasser et al. Nov 2013 B2
20020072828 Turner et al. Jun 2002 A1
20040123230 Lee et al. Jun 2004 A1
20090254792 Wang Oct 2009 A1
Foreign Referenced Citations (1)
Number Date Country
10-0511552 Aug 2005 KR
Related Publications (1)
Number Date Country
20120290891 A1 Nov 2012 US