In wireless local area networks utilizing frequency-hopping between different channels spaced over an allotted frequency band, two or more groups of transceivers in close proximity may be arranged to operate satisfactorily with the full bandwidth available to each by arranging that their hop sequences are kept separate. This may be achieved by arranging for the hop sequence of one group or of each group to skip at intervals from one point to another in the sequence, chosen at random.
A system and method employing a rate matching algorithm for providing an optimized pattern for puncturing parity bits of a turbo encoded data word of a given rate to produce a turbo encoded data word of a desired lower rate, to thus eliminate bits from said turbo encoded data word to be transmitted by a transmitter. The system and method determine a final amount of bits to be transmitted in the encoded data word, and determine, based on the final amount of bits in relation to the original number of bits in the encoded data word, the number of parity bits to be eliminated from transmission in the encoded data word. Because the parity bits typically have been inserted into the encoded data word by different encoders, the system and method uses a rate matching algorithm to provide an optimized pattern for puncturing the parity bits so that substantially the same number of parity bits provided by each encoder are punctured.
A method of providing forward error correction for data services uses a parallel concatenated convolutional code which is a Turbo Code comprising a plurality of eight-state constituent encoders wherein a plurality of data block sizes are used in conjunction with said Turbo Code. A variation uses the method in a cellular radio system. Another variation uses the method in both forward and reverse likes of a cellular radio system.
A method of interleaving blocks of indexed data of varying length is disclosed. The method includes the steps of: providing a set of basic Interleavers comprising a family of one or more permutations of the indexed data and having a variable length; selecting one of the basic Interleavers based upon a desired Interleaver length L; and adapting the selected basic Interleaver to produce an Interleaver having the desired Interleaver length L.
A method and apparatus for Turbo encoding uses a set of rate-compatible Turbo Codes optimized at high code rates and derived from a universal constituent code. The Turbo Codes have rate-compatible puncturing patterns. The method comprises: encoding a signal at a first and second encoder using a best rate 1/2 constituent code universal with higher code rates, the first encoder and the second encoder each producing a respective plurality of parity bits for each information bit; puncturing the respective plurality of parity bits at each encoder with a higher rate best puncturing patterns; and puncturing the respective plurality of parity bits at each encoder with a lower rate best puncturing pattern. In a variation, the best rate 1/2 constituent code represents a concatenation of polynomials 1+D.sup.2+D.sup.3 (octal 13) and 1+D+D.sup.3 (octal 15), D a data bit. A Turbo Encoder is provided which has hardware to implement the method.
A method of terminating two or more constituent encoders of a turbo encoder employing a turbo code, comprising the step of: generating tail input bits at each of two or more constituent encoders, including deriving the tail input bits from each of the two or more constituent encoders separately from a contents of shift registers within each of the two or more constituent encoders, after an encoding of information bits by the two or more constituent encoders; puncturing one or more tail output bits such that 1/R output tail bits are transmitted for each of a plurality of trellis branches, wherein R is a turbo code rate employed by the turbo encoder during an information bit transmission. In yet another variation, the step of puncturing the tail output bits further comprises the step of: transmitting, during trellis termination, the tail output bits, only if they are sent from an output branch of one of the two or more constituent encoders that are used during information bit transmission.