Utilizing variable-length inputs in an inter-sequence permutation turbo code system

Information

  • Patent Grant
  • 7797615
  • Patent Number
    7,797,615
  • Date Filed
    Thursday, August 31, 2006
    18 years ago
  • Date Issued
    Tuesday, September 14, 2010
    14 years ago
Abstract
The present invention relates to an inter-sequence permutation (ISP) encoder. The ISP encoder comprises: a receiving means to receive an information bit sequence input; a first outputting means for outputting a first code bit output; a second outputting means for outputting a second code bit sequence output; a bit-adding means coupled to the receiving means, the bit-adding means processing the received information bit sequence input prior to any subsequent processing in the ISP encoder; a first convolutional code encoder coupled between the bit-adding means and the first outputting means; a second convolutional code encoder; and an inter-sequence permutation interleaver coupled between the bit-adding means and the second convolutional code encoder. The second convolutional code encoder is coupled between the inter-sequence permutational interleaver and the second outputting means. Further, the ISP encoder comprises a third outputting means coupled to the bit-adding means to output a third code bit output or directly coupled to the receiving means. Alternatively, the ISP encoder comprises a fourth outputting means coupled to the inter-sequence permutation interleaver to output a fourth code bit sequence output.
Description
BACKGROUND OF THE INVENTION

(A) Field of the Invention


The present application relates to a method of utilizing variable-length inputs in an inter-sequence permutation turbo code system.


(B) Description of Related Art


In U.S. application Ser. No. 11/176,829 and U.S. application Ser. No. 11/414,433, an improved turbo code system is disclosed. However, persons skilled in the art may have noted that the ability of this system is limited. When all the sequence permuters (the first sequence permuter or the second sequence permutor in U.S. application Ser. No. 11/176,829) permute sequences with the same length, the system can only deal with inputted sequence (at encoder side) having the length of information bit sequence dividable to the length processed by the permuter without any remainder. However, this limit is undesired since practically information bit sequence can be of any length. The present invention is thus a solution to this problem and a teaching in utilizing an inputted sequence with variable-length in the inter-sequence permutation (ISP) turbo code system. The method can be further applied for the turbo code applying the almost regular permutation (ARP) interleaver, which is another kind of the inter-sequence permutation interleaver.


SUMMARY OF THE INVENTION

The present invention relates to an inter-sequence permutation (ISP) encoder. The ISP encoder comprising a receiving means for receiving an information bit sequence input; a first outputting means through which a first code bit sequence output is outputted; a second outputting means through which a second code bit sequence output is outputted; a bit-adding means coupled to the receiving means, the bit-adding (symbol-adding) means processing the received information bit sequence input prior to any subsequent processing in the ISP encoder; a first convolutional code encoder coupled between the bit-adding means and the first outputting means; a second convolutional code encoder; and an inter-sequence permutation interleaver. The inter-sequence permutation interleaver is coupled between the bit-adding means and the second convolutional code encoder. The second convolutional code encoder is coupled between the inter-sequence permutation interleaver and the second outputting means.


Further, the ISP encoder comprises a third outputting means through which a third code bit sequence output is outputted, wherein the third outputting means is coupled to the bit-adding means or directly coupled to the receiving means.


Alternatively, the ISP encoder comprises a fourth outputting means through which a fourth code bit sequence output is outputted, wherein the fourth outputting means is coupled to the inter-sequence permutation interleaver.


The present invention also relates to an inter-sequence permutation encoder. The ISP encoder comprises a receiving means for receiving an information bit sequence input; a first outputting means for outputting a first code bit sequence output; a second outputting means for outputting a second code bit sequence output; a bit-adding means coupled to the receiving means, wherein the bit-adding means processes the received information bit sequence input prior to any subsequent processing of the received information bit sequence input in the inter-sequence permutation encoder; a first convolutional code encoder coupled between the receiving means and the first outputting means; and a second convolutional code encoder coupled to the second outputting means; and an inter-sequence permutation interleaver coupled between the bit-adding means and the second convolutional code encoder. Further, the ISP encoder comprises a third outputting means coupled to the receiving means to output a third code bit sequence output.


Alternatively, the ISP encoder comprises a fourth outputting means coupled to the inter-sequence permutation interleaver to output a fourth code bit sequence output.





BRIEF DESCRIPTION OF THE DRAWINGS

The present invention is described below by way of examples with reference to the accompanying drawings which will make it easier for readers to understand the purpose, technical contents, characteristics and achievement of the present invention, wherein



FIG. 1 shows an example illustrating “shortening” and “puncturing” utilized in the ISP turbo code encoder;



FIG. 2 shows a first embodiment of the ISP encoder of the present invention;



FIG. 3 shows a second embodiment of the ISP encoder of the present invention;



FIG. 4 shows a third embodiment of the ISP encoder of the present invention;



FIG. 5 shows a fourth embodiment of the ISP encoder of the present invention; and



FIG. 6 shows a fifth embodiment of the ISP encoder of the present invention.





DETAILED DESCRIPTION OF THE INVENTION

The detailed description of a preferred embodiment is intended to illustrate the present invention, and is not intended to limit forms to embody the present invention.


Techniques that the invention adopts are conventional “shortening” and “puncturing.” Please first refer to FIG. 1. We assume that an inputted, first sequence 101 comprises 13 bits and all the sequence permuters process 4 bits. According to U.S. application Ser. No. 11/176,829 and U.S. application Ser. No. 11/414,433, such a sequence is not a valid sequence input to the ISP turbo code encoder. However, by adding three “0” bits in the sequence 101, it becomes a second sequence 102, which can be divided by 4 without leaving any remainder. Although we add “0” in this case, adding other kinds of symbol is also possible, e.g. “1”. Although we add three “0” at the end, exchanging prior information bits with at least one “0” is also possible. Please also note that meanings of “bit” and “symbol” can be interchanged in the present specification. An individual who fully understands the bit-adding operation could realize that adding bits makes the extended length of bit sequence valid for inputting to the inter-sequence permutation interleaver.


The sequence 102 can be permuted and encoded by the encoder performing inter-sequence permutation and convolutional code encoding (both have been discussed in U.S. application Ser. No. 11/176,829), the second sequence 102 becomes a third sequence 103 and a fourth sequence 104. In the third sequence 103 underlined digits in a sequence represent “added” bits. In the fourth sequence 104 underlined digits in a sequence represent “punctured” bits. After the process of inter-sequence permutation and/or convolutional code encoding, the added bits or the punctured bits are taken away, the resulting sequences are a fifth sequence 103′ and a sixth sequence 104′ respectively.


Adding the added bits before encoding and removing the added bits after encoding is called “shortening.” Removing the punctured bits is called “puncturing.” The shortening makes that the ISP turbo code system can encode a variable-length information bit sequence encodable when the length of information bit sequence is smaller than the designed length processed by the ISP turbo coding system. The puncturing makes that the length of code bit length matches the desired code bit length and the resultant code rate matches the desired code rate. One would easily note that essentially operations for removing the added bits and removing the punctured bits are very similar; therefore, we will uniformly call them “deleting” in the specification of the present application. However readers should keep in mind that in practice one would use different terms to refer to the deleting operation.


After the added bits are taken away, in order to increase bandwidth efficiency, the outputted “code bit sequences” can be further punctured, individually or jointly. This technique of “further puncturing” has been widely known, and we will just skip detailed description here.


The techniques described in previous 2 paragraphs and FIG. 1 can be embodied in U.S. application Ser. No. 11/176,829 and U.S. application Ser. No. 11/414,433 in various ways shown as follows. In FIGS. 2-4, receiving means and outputting means indicate physical portions for receiving and outputting sequences, respectively. They can be devices, circuit blocks, terminals, contacts, or simply wire junctions.



FIG. 2 is a first embodiment of the present invention, which evolves from FIG. 2 of U.S. application Ser. No. 11/176,829 by choosing outputs 106, 107 and 108 in FIG. 2 of U.S. application Ser. No. 11/176,829. In U.S. application Ser. No. 11/176,829, only three outputs (106, 107, 108, or 107, 108, 109) are required.


In FIG. 2, a bit-adding means 203 adds bits to an information bit sequence input received from a receiving means 202. After processed by the ISP encoder, every code bit sequence output at the first outputting means 207, second outputting means 208, and third outputting means 209 is subjected to a deleting operation in order to eliminate the “added” or “punctured” bits. As mentioned before, at least an additional puncturing operation can be further performed on the code bit sequence output in order to increase the bandwidth efficiency.


In FIG. 3, similarly every code bit sequence output at the first outputting means 207, second outputting means 208, and fourth outputting means 301 is subjected to a deleting operation in order to eliminate the “added” bits. As mentioned before, at least an additional puncturing operation can be further performed on the code bit sequence output in order to increase the bandwidth efficiency.


In FIG. 4, the third outputting means is directly coupled to the receiving means 202, thus eliminating the need to perform the deleting operation at the third outputting means 209. Similarly, every code bit output at the first outputting means 207 and second outputting means 208 is still subjected to a deleting operation in order to eliminate the “punctured” bits. As mentioned before, at least an additional puncturing operation can be further performed on the code bit sequence output in order to increase the bandwidth efficiency.


Encoders shown in FIG. 5 and FIG. 6 are similar to those in FIG. 4 and FIG. 3, respectively. A difference lies in that the first convolutional code encoder 205 directly receives sequences from the receiving means 202, since not all methods of convolutional code encoding requires “shortening” or “puncturing” beforehand. As mentioned before, at least an additional puncturing operation can be further performed on the code bit sequence output in order to increase the bandwidth efficiency.


In FIG. 2, FIG. 3, FIG. 4, FIG. 5, and FIG. 6, the first and second convolutional code encoders can adopt as least one of the following methods: tail-biting convolutional encoding, tail-padding convolutional code encoding. The convolutional code encoders can be replaced by other encoding methods such as Reed-Muller code, BCH code . . . etc. Multiple sequences after and before inter-sequence permutation interleaver can be separately encoded.


Naturally, an individual who fully understand the present invention could realize that in fact, only sequences passing through the inter-sequence permutation interleaver requires “shortening” or “puncturing” operations. Therefore, the deleting operations do not require to be only performed at the outputting means. They can be performed right following the inter-sequence permutation interleaver, or prior to a convolutional code encoder if sequences passing through that convolutional code encoder do not require “shortening” or “puncturing.”


The almost regular permutation is also a kind of inter-sequence permutation interleaver and the “shortening” or “puncturing” can be applied for the turbo code applying the almost regular permutation as interleaver to encode a bit sequence with variable length.

Claims
  • 1. An inter-sequence permutation encoder, at least comprising: a receiving means for receiving an information bit sequence input;a first outputting means for outputting a first code bit sequence output;a second outputting means for outputting a second code bit sequence output;a bit-adding means coupled to the receiving means, wherein the bit-adding means processing the received information bit sequence input prior to any subsequent processing of the received information bit sequence input in the inter-sequence permutation encoder;a first convolutional code encoder coupled between the bit-adding means and the first outputting means; anda second convolutional code encoder coupled to the second outputting means; andan inter-sequence permutation interleaver coupled between the bit-adding means and the second convolutional code encoder,wherein the first and second convolutional code encoders perform as least one of the following methods: tail-biting convolutional encoding, tail-padding convolutional code encoding.
  • 2. The inter-sequence permutation encoder as claimed in claim 1, further comprising a third outputting means coupled to the bit-adding means to output a third code bit sequence output.
  • 3. The inter-sequence permutation encoder as claimed in claim 2, wherein the third outputting means performs a deleting operation in order to eliminate bits added by the bit-adding means.
  • 4. The inter-sequence permutation encoder as claimed in claim 3, wherein the third code bit sequence output undergoes at least an additional puncturing operation.
  • 5. The inter-sequence permutation encoder as claimed in claim 2, wherein the third code bit sequence output undergoes at least an additional deleting operation.
  • 6. The inter-sequence permutation encoder as claimed in claim 1, further comprising a third outputting means coupled to the receiving means to output a third code bit sequence output.
  • 7. The inter-sequence permutation encoder as claimed in claim 6, wherein the third code bit sequence output undergoes at least an additional deleting operation.
  • 8. The inter-sequence permutation encoder as claimed in claim 1, further comprising a fourth outputting means coupled to the inter-sequence permutation interleaver to output a fourth code bit sequence output.
  • 9. The inter-sequence permutation encoder as claimed in claim 8, wherein the fourth outputting means performs a deleting operation in order to eliminate bits added by the bit-adding means.
  • 10. The inter-sequence permutation encoder as claimed in claim 9, wherein the fourth code bit sequence output undergoes at least an additional puncturing operation.
  • 11. The inter-sequence permutation encoder as claimed in claim 8, wherein the fourth code bit sequence output undergoes at least an additional deleting operation.
  • 12. The inter-sequence permutation encoder as claimed in claim 1, wherein methods adopted by the convolutional code encoders are replaced by at least one of the following methods: Reed-Muller code and BCH code.
  • 13. The inter-sequence permutation encoder as claimed in claim 12, wherein the first or second code bit sequence output undergoes at least an additional puncturing operation.
  • 14. The inter-sequence permutation encoder as claimed in claim 12, wherein the first code bit sequence output undergoes at least an additional puncturing operation.
  • 15. The inter-sequence permutation encoder as claimed in claim 12, wherein the second code bit sequence output undergoes at least an additional puncturing operation.
  • 16. The inter-sequence permutation encoder as claimed in claim 1, wherein sequences processed after and before the inter-sequence permutation interleaver are separately encoded.
  • 17. The inter-sequence permutation encoder as claimed in claim 1, wherein the first and second outputting means perform deleting operations in order to eliminate bits added by the bit-adding means.
  • 18. The inter-sequence permutation encoder as claimed in claim 1, wherein the first and second code bit sequence outputs undergo at least an additional puncturing operation.
  • 19. The inter-sequence permutation encoder as claimed in claim 1, wherein the second outputting means performs deleting operations in order to eliminate bits added by the bit-adding means.
  • 20. The inter-sequence permutation encoder as claimed in claim 1, wherein the first outputting means performs deleting operations in order to eliminate bits added by the bit-adding means.
  • 21. The inter-sequence permutation encoder as claimed in claim 1, wherein the first code bit sequence output undergoes at least an additional puncturing operation.
  • 22. The inter-sequence permutation encoder as claimed in claim 1, wherein the second code bit sequence output undergoes at least an additional puncturing operation.
  • 23. An inter-sequence permutation encoder, at least comprising: a receiving means for receiving an information bit sequence input;a first outputting means for outputting a first code bit sequence output;a second outputting means for outputting a second code bit sequence output;a bit-adding means coupled to the receiving means, wherein the bit-adding means processes the received information bit sequence input prior to any subsequent processing of the received information bit sequence input in the inter-sequence permutation encoder;a first convolutional code encoder coupled between the receiving means and the first outputting means;a second convolutional code encoder coupled to the second outputting means; andan inter-sequence permutation interleaver coupled between the bit-adding means and the second convolutional code encoder,wherein the first and second convolutional code encoders perform as least one of the following methods: tail-biting convolutional encoding, tail-padding convolutional code encoding.
  • 24. The inter-sequence permutation encoder as claimed in claim 23, further comprising a third outputting means coupled to the receiving means to output a third code bit sequence output.
  • 25. The inter-sequence permutation encoder as claimed in claim 24, wherein the third code bit sequence output undergoes at least an additional puncturing operation.
  • 26. The inter-sequence permutation encoder as claimed in claim 23, further comprising a fourth outputting means coupled to the inter-sequence permutation interleaver to output a fourth code bit sequence output.
  • 27. The inter-sequence permutation encoder as claimed in claim 26, wherein the fourth outputting means performs a deleting operation in order to eliminate bits added by the bit-adding means.
  • 28. The inter-sequence permutation encoder as claimed in claim 27, wherein the fourth code bit sequence output undergoes at least an additional puncturing operation.
  • 29. The inter-sequence permutation encoder as claimed in claim 23, wherein methods adopted by the convolutional code encoders are replaced by at least one of the following methods: Reed-Muller code and BCH code.
  • 30. The inter-sequence permutation encoder as claimed in claim 23, wherein sequences processed after and before the inter-sequence permutation interleaver are separately encoded.
  • 31. The inter-sequence permutation encoder as claimed in claim 23, wherein the second outputting means performs a deleting operation in order to eliminate bits added by the bit-adding means.
  • 32. The inter-sequence permutation encoder as claimed in claim 31, wherein the first or second code bit sequence output undergoes at least an additional puncturing operation.
  • 33. The inter-sequence permutation encoder as claimed in claim 31, wherein the first code bit sequence output undergoes at least an additional puncturing operation.
  • 34. The inter-sequence permutation encoder as claimed in claim 31, wherein the second code bit sequence output undergoes at least an additional puncturing operation.
Parent Case Info

The present application is a continuation-in-part application of U.S. application Ser. No. 11/176,829, filed on Jul. 7, 2005 which is entitled “AN INTER-SEQUENCE PERMUTATION TURBO CODE SYSTEM AND OPERATION METHODS THEREOF,” and U.S. application Ser. No. 11/414,433, filed on Apr. 28, 2006 which is entitled “NETWORK FOR PERMUTATION OR DE-PERMUTATION UTILIZED BY CHANNEL CODING ALGORITHM.”

US Referenced Citations (57)
Number Name Date Kind
4400768 Tomlinson Aug 1983 A
4433415 Kojima Feb 1984 A
5224100 Lee et al. Jun 1993 A
5392299 Rhines et al. Feb 1995 A
5519734 Ben-Efraim May 1996 A
5530707 Lin Jun 1996 A
5729560 Hagenauer et al. Mar 1998 A
5734962 Hladik et al. Mar 1998 A
5812601 Schramm Sep 1998 A
5815515 Dabiri Sep 1998 A
6014761 Lachish et al. Jan 2000 A
6023783 Divsalar et al. Feb 2000 A
6044116 Wang Mar 2000 A
6182261 Haller et al. Jan 2001 B1
6292918 Sindhushayana et al. Sep 2001 B1
6373831 Secord et al. Apr 2002 B1
6414988 Ling Jul 2002 B1
6437714 Kim et al. Aug 2002 B1
6477680 Mujtaba Nov 2002 B2
6553516 Suda et al. Apr 2003 B1
6560362 Piret et al. May 2003 B1
6560748 Li May 2003 B2
6571369 Li May 2003 B1
6578170 Piret et al. Jun 2003 B1
6603412 Gatherer et al. Aug 2003 B2
6618371 Cao Sep 2003 B1
6631491 Shibutani et al. Oct 2003 B1
6678843 Giulietti et al. Jan 2004 B2
6684365 Murayama et al. Jan 2004 B1
6697990 El-Gamal et al. Feb 2004 B2
6728927 Crozier Apr 2004 B2
6745362 Carlach et al. Jun 2004 B1
6766489 Piret et al. Jul 2004 B1
6845482 Yao et al. Jan 2005 B2
6859906 Hammons et al. Feb 2005 B2
6903665 Akhter et al. Jun 2005 B2
6944727 Yokokawa Sep 2005 B2
6957375 Richardson Oct 2005 B2
6961888 Jin et al. Nov 2005 B2
7058874 Zhou Jun 2006 B2
7137044 Ha et al. Nov 2006 B2
7155642 Han Dec 2006 B2
7180968 Miyauchi et al. Feb 2007 B2
20020159423 Yao et al. Oct 2002 A1
20030002474 Alexander et al. Jan 2003 A1
20030014715 Lobinger et al. Jan 2003 A1
20030041293 Zheng et al. Feb 2003 A1
20030058954 He Mar 2003 A1
20030154343 Yokokawa Aug 2003 A1
20050071727 Zheng et al. Mar 2005 A1
20050071728 Zheng et al. Mar 2005 A1
20050076286 Zheng et al. Apr 2005 A1
20050216700 Honary et al. Sep 2005 A1
20060039555 Lee et al. Feb 2006 A1
20070011557 Zheng et al. Jan 2007 A1
20070255849 Zheng Nov 2007 A1
20090077431 Zheng Mar 2009 A1
Foreign Referenced Citations (2)
Number Date Country
0 179 401 Apr 1986 EP
0 313 787 May 1989 EP
Related Publications (1)
Number Date Country
20070022353 A1 Jan 2007 US
Continuation in Parts (2)
Number Date Country
Parent 11414433 Apr 2006 US
Child 11513158 US
Parent 11176829 Jul 2005 US
Child 11414433 US