The present invention relates to error correction in coding schemes for digital communication systems, and more particularly to design optimization for Interleavers of any size, which can be completely specified using only a few design parameters (i.e. a parameterized interleaver).
In communication systems, system performance is aided by error control codes. Nearly all communications systems rely on some form of error control for managing errors that may occur due to noise and other factors during transmission of information through a communication channel. These communications systems can include satellite systems, fiber-optic systems, cellular systems, and radio and television broadcasting systems. Efficient error control schemes implemented at the transmitting end of these communications systems have the capacity to enable the transmission of data including audio, video, text, etc. with very low error rates within a given signal-to-noise ratio (SNR) environment. Powerful error control schemes also enable a communications system to achieve target error performance rates in environments with very low SNR, such as in satellite and other wireless systems where noise is prevalent and high levels of transmission power are costly, if even feasible.
Thus, broad classes of powerful error control schemes that enable reliable transmission of information have emerged including convolutional codes, low density parity check (LDPC) codes, and turbo codes. Both LDPC codes as well as some classes of turbo codes have been successfully demonstrated to approach near the theoretical bound (i.e., Shannon limit). Although long constraint length convolutional codes can also approach the Shannon limit, decoder design complexity prevents practical, wide spread adoption. LDPC codes and turbo codes, on the other hand, can achieve low error rates with lower complexity decoders.
In frequency division multiplexed (FDM) systems, adjacent channel interference (ACI) can seriously impair performance especially when high bandwidth efficiencies are desired. This is because in order to achieve high bandwidth/spectral efficiencies, the frequency separation between the adjacent channels (carriers) must be reduced, causing an increase in ACI and resulting in performance degradation. The performance can be improved by applying interference cancellation at the receiver. Such a design, however, entails an increase in the complexity. Alternatively, the performance could also be improved through a more judicious choice of the modulation and channel (error correction) coding. Bandwidth efficiency can be obtained by choosing modulations such as continuous phase modulation (CPM). Through a careful design of the CPM pulse shape and selection of the remaining modulation parameters, such as the alphabet size M and modulation index h, the power spectrum can be shaped to improve the resilience to ACI.
A pragmatic approach for attempting to achieve energy efficient communication would be the concatenation of a small constraint length binary error correction code and the modulator using a bit interleaver and the application of the “turbo-principle” of iterating between the demodulator and decoder at the receiver. Interleaving is a process of reordering a sequence of symbols or bits in a predetermined manner. “Interleaver size” is equal to the size of the sequence. The apparatus performing the interleaving is referred to herein as an Interleaver. A Turbo Interleaver serves to reorder an input data sequence in a pseudo-random fashion prior to an encoding by a second of the constituent codes. This approach is commonly known as bit interleaved coded modulation with iterative decoding (BICM-ID). The primary goals for error coding (FEC) and interleaver design are flexibility, effective performance, complexity (e.g., implementation complexity) and scalability.
A main problem in such communication systems, however, is an early occurrence of the error floor along the curve of error rate (e.g., frame error rate) with respect to signal to noise ratio. As the signal to noise ratio is improved the frame error rate generally improves in a relative fashion. Particularly, at higher frame error rates, the error rate improves at a sharper slope with respect to improvement in the signal to noise ratio (along the curve of frame error rate with respect to signal to noise ratio), and then at some point, the slop or rate of improvement in the frame error rate drops off or flattens out at lower frame error rates (also known as error floors). This phenomenon is dominated by the interleaver design. The goal of the interleaver design is to prevent early error floors—in other words, the goal is to set the point at which the frame error rate improvement drops off at a lowest practical error rate (e.g., at frame error rates of 10−5 or 10−6).
Coded systems employing small constraint length binary convolutional codes in a BICM-ID framework have been shown to have very good convergence thresholds, and hence perform very well in the waterfall region of the error rate curve. To prevent the early error floors that typically occur in these systems, an S-random bit interleaver is often used between the convolutional encoder and the modulator. The underlying principle behind S-random interleavers is to avoid mapping neighbor positions of an original input sequence to another neighbor position of the interleaved sequence within a window of size S. The design goal in S-random interleavers is to maximize S while preserving the above principle.
S-random interleavers, however, suffer from a main drawback in that they lack a general rule that can be used to specify an interleaver of any size N. A designer, therefore, has no practical option other than creating an explicit listing or specification for the entire interleaver for a given N. Also, S-random interleavers have to be redesigned every time the interleaver size is changed, and there is typically no requirement of any resemblance between the interleavers with similar sizes. Further, specification of the entire interleaver requires a respective amount of memory storage for each interleaver, and the specification of multiple interleavers of differing sizes multiplies the memory requirements. Accordingly, the memory required to store the entire interleaver generally renders the S-random interleaver as an impractical option for use in communication systems in which the interleaver length spans a wide range of values, for instance, from a few hundred bits to several thousand bits.
It is, therefore, desirable to have a general interleaver design based on an interleaver design rule that concisely defines interleavers of any size, which can be completely specified using only a few design parameters (i.e. a parameterized interleaver).
The present invention advantageously addresses the needs above, as well as other needs, by providing a method, system, and software for a parameterized interleaver design process, which optimizes the design for interleavers of any size, and can be completely specified using only a few design parameters. The interleaver design process of the present invention offers a considerable reduction in memory requirement relative to the S-random interleaver. Also, simulation results show that interleavers designed via the methodology of the present invention either meet or improve on the performance of typical S-random interleavers.
According to an exemplary embodiment, a method of generating an interleaver π(i) of a length N comprises defining a number of subpermutation masks. The method further comprises partitioning a one intermediate interleaver permutation into a number of subgroups, wherein the number of subgroups corresponds with the number of subpermutation masks. Each of the subgroups of the one intermediate interleaver permutation is partitioned into a number of further subgroups, and each of the subpermutation masks is applied to each of the further subgroups of a corresponding subgroup of the one intermediate interleaver permutation, resulting in a corresponding portion of a further intermediate interleaver permutation. The resulting interleaver π(i) is generated based at least in part on the one intermediate and the further intermediate interleaver permutations.
According to a further exemplary embodiment, the method of generating an interleaver π(i) of a length N further comprises defining a number of initial subpermutation masks. The method also comprises partitioning an initial interleaver permutation vector into a number of subvectors, wherein the number of subvectors corresponds to the number of initial subpermutation masks. Each of the subvectors is partitioned into a number of subgroups, and each of the initial subpermutation masks is applied to each of the subgroups of a corresponding subvector, resulting in a corresponding portion of a subvector intermediate interleaver permutation. An additional intermediate interleaver permutation is generated based at least in part on the initial interleaver permutation vector. The one intermediate interleaver permutation is generated based at least in part on the subvector intermediate and the additional intermediate interleaver permutations, wherein the one intermediate interleaver permutation is of the length N.
According to a further exemplary embodiment, a method of generating an interleaver π(i) of a length N comprises defining a set of interleaver design parameters, including s, p, N1, K1, K2 and K3, and defining a plurality of subpermutation masks, π1, π2, π3, π4, π5, and π6. An initial interleaver permutation vector πinitial is partitioned into a first subvector πinitial1 of a length N1 and a second subvector πinitial2 of a length N−N1. The first subvector πinitial1 is partitioned into a number of first subgroups, and the subpermutation mask π1 is applied to each of the first subgroups, resulting in a first portion of a first intermediate interleaver permutation πintermediate1(i), where i=0, 1, . . . , N1−1. The second subvector πinitial2 is partitioned into a number of second subgroups, and the subpermutation mask π2 is applied to each of the second subgroups, resulting in a second portion of the first intermediate interleaver permutation πintermediate1(i), where i=N1, . . . , N−1. The method further comprises generating a second intermediate interleaver permutation πintermediate2(i), based at least in part on the initial interleaver permutation vector, where i=0, 1, . . . , N−1, and generating a third intermediate interleaver permutation πintermediate3(i), based at least in part on the first and second intermediate interleaver permutations, where i=0, 1, . . . , N−1. The third intermediate interleaver permutation πintermediate3 is partitioned into four subgroups, πintermediate31, πintermediate32, πintermediate33, and πintermediate34, having K1, K2, K3 and K4 elements, respectively, wherein K1+K2+K3+K4=N. The subgroup πintermediate31 is partitioned into K1/12 subgroups, and the subpermutation mask π3 is applied to each of the K1/12 subgroups, resulting in a first portion of a fourth intermediate interleaver permutation πintermediate4(i), where i=0, 1, . . . , K1−1. The subgroup πintermediate32 is partitioned into K2/12 subgroups, and the subpermutation mask π4 is applied to each of the K2/12 subgroups, resulting in a second portion of the fourth intermediate interleaver permutation πintermediate4(i), where i=K1, . . . , (K1+K2)−1. The subgroup πintermediate33 is partitioned into K3/12 subgroups, and the subpermutation mask π5 is applied to each of the K3/12 subgroups, resulting in a third portion of the fourth intermediate interleaver permutation πintermediate4(i), where i=(K1+K2), . . . , (K1+K2+K3)−1. The subgroup πintermediate34 is partitioned into K4/12 subgroups, and the subpermutation mask π6 is applied to each of the K4/12 subgroups, resulting in a fourth portion of the fourth intermediate interleaver permutation πintermediate4(i), where i=(K1+K2+K3), . . . , N−1. The resulting interleaver π(i) is generated based at least in part on the third and fourth intermediate interleaver permutations, where =0, 1, . . . , N−1.
According to another exemplary embodiment, an apparatus for generating an interleaver π(i) of a length N, comprises a processor configured to partition a one intermediate interleaver permutation into a number of subgroups, wherein the number of subgroups corresponds with a number of predetermined subpermutation masks. The processor is further configured to partition each of the subgroups of the one intermediate interleaver permutation into a number of further subgroups, and to apply each of the subpermutation masks to each of the further subgroups of a corresponding subgroup of the one intermediate interleaver permutation, resulting in a corresponding portion of a further intermediate interleaver permutation. The processor is further configured to generate the resulting interleaver π(i) based at least in part on the one intermediate and the further intermediate interleaver permutations.
According to a further exemplary embodiment, the processor is further configured to partition an initial interleaver permutation vector into a number of subvectors, wherein the number of subvectors corresponds to a number of predetermined initial subpermutation masks. Each of the subvectors is partitioned into a number of subgroups, and each of the initial subpermutation masks is applied to each of the subgroups of a corresponding subvector, resulting in a corresponding portion of a subvector intermediate interleaver permutation. An additional intermediate interleaver permutation is generated based at least in part on the initial interleaver permutation vector. The one intermediate interleaver permutation is generated based at least in part on the subvector intermediate and the additional intermediate interleaver permutations, wherein the one intermediate interleaver permutation is of the length N.
According to a further exemplary embodiment, an apparatus for generating an interleaver π(i) of a length N, comprises processor configured to partition an initial interleaver permutation vector πinitial into a first subvector πinitial1 of a length N1 and a second subvector πinitial2 of a length N−N1, wherein N1 comprises a predetermined parameter. The processor is further configured to partition the first subvector πinitial1 into a number of first subgroups, and to apply a predetermined subpermutation mask π1 to each of the first subgroups, resulting in a first portion of a first intermediate interleaver permutation πintermediate1(i), where i=0, 1, . . . , N1−1. The processor is further configured to partition the second subvector πinitial2 into a number of second subgroups, and to apply a predetermined subpermutation mask π2 to each of the second subgroups, resulting in a second portion of the first intermediate interleaver permutation πintermediate1(i), where i=N1, . . . , N−1. The processor is further configured to generate a second intermediate interleaver permutation πintermediate2(i), based at least in part on the initial interleaver permutation vector, where i=0, 1, . . . , N−1, and to generate a third intermediate interleaver permutation πintermediate3(i), based at least in part on the first and second intermediate interleaver permutations, where i=0, 1, . . . , N−1. The processor is further configured to partition the third intermediate interleaver permutation πintermediate3 into four subgroups, πintermediate31, πintermediate32, πintermediate33 and πintermediate34, having K1, K2, K3 and K4 elements respectively, wherein K1, K2 and K3 comprise predetermined parameters, and K1+K2+K3+K4=N. The processor is further configured to partition the subgroup πintermediate31 into K1/12 subgroups, and to apply a predetermined subpermutation mask π3 to each of the K1/12 subgroups, resulting in a first portion of a fourth intermediate interleaver permutation πintermediate4(i), where i=0, 1, . . . , K1−1. The processor is further configured to partition the subgroup πintermediate32 into K2/12 subgroups, and to apply a predetermined subpermutation mask π4 to each of the K2/12 subgroups, resulting in a second portion of the fourth intermediate interleaver permutation πintermediate4(i), where i=K1, . . . , (K1+K2)−1. The processor is further configured to partition the subgroup πintermediate33 into K3/12 subgroups, and to apply a predetermined subpermutation mask π5 to each of the K3/12 subgroups, resulting in a third portion of the fourth intermediate interleaver permutation πintermediate4(i), where i=(K1+K2), . . . , (K1+K2+K3)−1. The processor is further configured to partition the subgroup πintermediate34 into K4/12 subgroups, and to apply a predetermined subpermutation mask π6 to each of the K4/12 subgroups, resulting in a fourth portion of the fourth intermediate interleaver permutation πintermediate4(i), where i=(K1+K2+K3), . . . , N−1. The processor is further configured to generate the resulting interleaver π(i) based at least in part on the third and fourth intermediate interleaver permutations, where i=0, 1, . . . , N−1.
Still other aspects, features, and advantages of the present invention are readily apparent from the following detailed description, simply by illustrating a number of particular embodiments and implementations, including the best mode contemplated for carrying out the present invention. The present invention is also capable of other and different embodiments, and its several details can be modified in various obvious respects, all without departing from the spirit and scope of the present invention. Accordingly, the drawing and description are to be regarded as illustrative in nature, and not as restrictive.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings and in which like reference numerals refer to similar elements and in which:
A method, system, and software for a parameterized interleaver design process, which optimizes the design for interleavers of any size, and can be completely specified using only a few design parameters is described. In the following description, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the invention. It is apparent, however, that the invention may be practiced without these specific details or with an equivalent arrangement. In other instances, well known structures and devices are shown in block diagram form in order to avoid unnecessarily obscuring the invention.
Although certain embodiments of the present invention are described with respect to interleaver designs employed with continuous phase modulation (CPM), it is contemplated that these embodiments have applicability to other modulation schemes, such as frequency shifted keying (FSK), quadrature phase shifted keying (QPSK), offset quadrature phase shifted keying (OQPSK), quadrature amplitude modulation (QAM), adaptive coding and modulation (ACM), and the like.
FEC is required in terrestrial and satellite systems to provide high quality communication over a radio frequency (RF) propagation channel, which induces signal waveform and spectrum distortions, including signal attenuation (freespace propagation loss), multi-path induced fading and adjacent channel interference. These impairments drive the design of the radio transmission and receiver equipment; exemplary design objectives include selecting modulation formats, error control schemes, demodulation and decoding techniques and hardware components that together provide an efficient balance between system performance and implementation complexity. Differences in propagation channel characteristics, such as between terrestrial and satellite communication channels, naturally result in significantly different system designs. Likewise, existing communications systems continue to evolve in order to satisfy increased system requirements for new higher rate or higher fidelity communication services.
Satellite communications system 120 includes a satellite 121 that supports communication among multiple satellite terminals (STs) 123, 125 and a hub 127. The hub 127 may assume the role of a Network Operations Control Center (NOCC), which controls the access of the STs 123, 125 to the network 120 and also provides element management functions and control of the address resolution and resource management functionality. The satellite 121, in an exemplary embodiment, operates as a packet switch (e.g., at a data link layer) that provides direct unicast and multicast communication among the STs 123, 125. The STs 123, 125 provide connectivity to one or more hosts 129, 131, respectively. According to one embodiment of the present invention, the system 120 has a fully meshed architecture, whereby the STs 123, 125 may directly communicate.
In certain embodiments, for terminals of differing capabilities to communicate with each other, an exchange of information regarding the capabilities among the communicating terminals is needed. Specifically, the common air interface needs to support a discovery of the terminal's capabilities profile (or context information). These capabilities can include encryption scheme, compression scheme, segmentation and reassembly (SAR) scheme, automatic repeat request (ARQ) scheme, Quality-of-Service (QoS) parameters, power levels, modulation and coding schemes, power control algorithms, and link adaptation capabilities.
Under a conventional approach, terminal profile can be readily exchanged over a network with a star topology where no peer-to-peer communication exists. For example, in the General Packet Radio Service (GPRS)/Universal Mobile Telecommunications System (UMTS) family of protocols, such capabilities profiles include a packet data protocol (PDP) context and a mobility management context. In an exemplary embodiment, the concepts of PDP context and mobility management context are combined and the term packet data protocol (PDP) context is used in general to refer to terminal capabilities. It is recognized that these terminals can be mobile as well as non-mobile. According to an exemplary embodiment, this PDP context, for example, which can provide information about the encryption algorithm, compression algorithm, modes of data link layer communication, and physical layer transfer capabilities is combined by the transmit ST with the Quality of Service (QoS) of a pending data flow to determine a packet transfer context to use in transmission of the flow. If a PDP context has been previously established, then the sending ST can autonomously create the packet transfer context, which both satisfies the QoS of the data flow and is compatible with the receive ST capabilities.
According to one embodiment, the exchange of terminal profile can be executed over a meshed network, in a peer-to-peer manner. The STs 123, 125 support the use of a negotiation procedure to determine the optimal configuration for transmission and reception of data. If a protocol implements control procedures or options in newer versions (i.e., flow-control/rate-control), older protocol versions are able to detect the initiation as a new unsupported procedure and report the same to the peer with minimal disruption in the flow of traffic.
The ST-ST protocol advantageously takes into account that even for peers of the same version, some capabilities may not necessarily be always supported due to local temporal processing/memory/congestion-related constraints. Additionally, the ST-ST protocol design provides for rapid developments in data communication technology. For each ST 123, 125, there exist some configuration information, including network configuration, network service provider (NSP) configuration, software configuration, and user configuration, as indicated by the NOCC 127. These configurations relate to the features that the ST 123, 125 supports and offers to the user, and have a direct bearing on the transmission and reception capabilities.
To facilitate the flow of data from one peer ST 123 to another ST 125, potentially configured with different capabilities, a packet transfer context is employed. Such a common feature set depends on the PDP contexts of the two STs 123, 125. Further, this common feature set may also depend on the QoS of the flow, as well as the loading and status of the two STs at that point of time. In an exemplary embodiment, the packet transfer context is unidirectional and valid only for the transmit ST to send packets to the specified receive ST; thus, the packet transfer context may be unique to a given pair of STs.
System Model:
Transmitter.
In one exemplary embodiment, in the transmitter of
The output of the encoder is fed to the interleaver. Interleaving is a process of rearranging the ordering of a data sequence in a one to one deterministic format. The inverse of this process is calling deinterleaving, which restores the received sequence to its original order. Interleaving is used to enhance the error correcting capability of coding. The interleaver π contains the permutation indicies such that the interleaved codeword is given by b=[b0, b1, . . . , bN-1]=[b′π(0), b′π(1), . . . , b′π(N-1)]. As an example, if the codeword is b′=[1 1 0 0 1 1] and the interleaver is π=[3 0 5 1 4 2], the bit sequence at the output of the interleaver is b=[0 1 1 1 1 0]. The interleaved bits are mapped to symbols and input to the modulator.
The CPM modulator generates a modulated signal whose phase transitions are continuous from one symbol epoch to the next. The phase continuity ensures a power spectrum with relatively small side lobes. The power spectrum and performance of the CPM signal is influenced by the alphabet size M, the modulation index h, the type of the CPM pulse shape and the width L of the pulse shape. The complex baseband CPM signal is given by
Channel.
The modulated CPM signal is transmitted through the channel which distorts the signal by adding both noise and adjacent carrier interference. The noise is modeled as zero-mean, additive white Gaussian noise (AWGN) and the adjacent carrier interference is from four equally spaced carriers, assuming two carriers on either side of the desired CPM signal. If fi and fj are the center frequencies for the ith and the jth carriers respectively, then the frequency separation between two immediate neighbors is Δf=|fi−fj|. It is also assumed that the carriers are homogenous, i.e. all carriers use identical CPM parameters and error correction coding.
Receiver.
The CPM correlator bank 303 filters the received signal with Nm possible reference signals, where Nm is a finite integer number and depends on the choice of the CPM modulation parameters. The CPM correlator bank 303 provides a matrix, which contains statistical indication as to which of the possible transmitted signals may be the received signal.
The CPM detector 305 uses the statistics provided by the CPM correlator bank 303 to perform decoding using a decoding algorithm, such as a Viterbi or BCJR algorithm, for providing an estimate of the transmitted symbols (or equivalently of the transmitted codebits). The CPM detector 305 can also receive interleaved a priori probability information of the transmitted codebits being either a 1 or a 0 (i.e. bits generated by the convolutional code), provided by the channel decoder 309, in order to provide a better estimate of the transmitted signal. The probability estimates of the transmitted codebits, also known as extrinsic information, generated by the CPM detector 305 is deinterleaved by the deinterleaver 311, and input to the channel decoder 309.
The channel decoder 309 uses the deinterleaved probabilities in its decoding algorithm (e.g., Viterbi, BCJR) and generates an estimate of the transmitted information bits. In addition, the channel decoder 309 also provides probability estimates of the transmitted codebits, which, after interleaving, are used as the a priori probability information by the CPM detector 305. This iterative exchange of probabilities between the CPM detector 305 and the channel decoder 309 is continued until a maximum number of iterations are performed, such that, with each iteration, the decoder can provide more accurate estimates of the transmitted information bits.
Parameterized Interleaver Design Procedure:
In one embodiment, the transmitter 200, for example, performs the processes 1000A and 1000B, implemented in, for instance, a chip set including a processor and a memory as shown in
More specifically, as shown in
πinitial=[0,1,2, . . . ,N−1].
Referring to
πinitial1=[0,1,2, . . . ,N1−1],
and
πinitial2=[N1,N1+1, . . . ,N−1],
where
πinitial2(0)=πinitial(N1).
Then, πinitial1 is divided in N1/12 subgroups (each of a length 12), and the subpermutation mask π121=[9, 11, 8, 6, 10, 2, 4, 0, 7, 5, 1, 3] is applied to each of the N1/12 subgroups. The resulting intermediate interleaver permutations are given by:
πintermediate1(i)=πinitial1((j−1)×12+π121(R12[i])),
i=0,1, . . . ,N1−1,
Then, πinitial2 is partitioned into (N−N1)/12 subgroups (each of a length 12), and the subpermutation mask π122=[8, 11, 6, 4, 0, 7, 3, 10, 1, 5, 9, 2] is applied to each of the (N−N1)/12 subgroups. The resulting intermediate interleaver permutations are given by:
πintermediate1(i)=πinitial2((j−1)×12+π122(R12[i])),
i=N1,1, . . . ,N−1,
Then, at step 1019, a second intermediary interleaver permutation is generated based on the initial interleaver permutation vector. Further, at step 1021, a first intermediate interleaver permutation is generated based on the first intermediary and the second intermediary interleaver permutations, wherein the first intermediate interleaver permutation is of the length N.
More specifically, as shown in
πintermediate2(i)=πinitial(RN[s+p×i]),
i=0,1, . . . ,N−1,
As shown in
πintermediate3(i)=πintermediate2(πintermediate1(i)),
i=0,1, . . . ,N−1.
At step 1023, a number of further subpermutation masks are defined for application to subgroups of a further intermediate interleaver permutation, which, for the present embodiment number four masks, again with 12 elements each. Then, the first intermediate interleaver permutation is partitioned into a number of subgroups (step 1025), where the number of subgroups corresponds with the number of subpermutation masks. For example, according to the present embodiment, the first intermediate interleaver permutation is partitioned into four subgroups, corresponding to the four subpermutation masks. At step 1027, each of the subgroups of the first intermediate interleaver permutation is further partitioned into a number of subgroups, where, in the present example, each such subgroup contains 12 elements. Then, per step 1029, each of the subpermutation masks is applied to each of the further subgroups of a corresponding subgroup of the first intermediate interleaver permutation, resulting in a corresponding portion of a second intermediate interleaver permutation. Accordingly, for the present embodiment, (1) a first of the four subpermutation masks is applied to each of the subgroups of a first of the four subgroups of the first intermediate interleaver permutation, resulting in a first portion of the second intermediate interleaver permutation, (2) a second of the four subpermutation masks is applied to each of the subgroups of a second of the four subgroups of the first intermediate interleaver permutation, resulting in a second portion of the second intermediate interleaver permutation, (3) a third of the four subpermutation masks is applied to each of the subgroups of a third of the four subgroups of the first intermediate interleaver permutation, resulting in a third portion of the second intermediate interleaver permutation, and (4) the fourth of the four subpermutation masks is applied to each of the subgroups of the fourth of the four subgroups of the first intermediate interleaver permutation, resulting in a fourth portion of the second intermediate interleaver permutation. Finally, at step 1031, the interleaver π(i) is generated based on the first and second intermediate interleaver permutations.
More specifically, referring to
First, πintermediate31 is subdivided into K1/12 subgroups, and the subpermutation mask π123=[4, 10, 5, 8, 3, 6, 9, 11, 1, 7, 0, 2] is applied to each of the K1/12 subgroups, such that:
πintermediate4(i)=πintermediate31((j−1)×12+π123(R12[i])),
i=0,1, . . . ,K1−1,
Second, πintermediate32 is divided into K2/12 subgroups, each having 12 elements, and the subpermutation mask π124=[5, 8, 10, 2, 6, 4, 7, 1, 3, 9, 11, 0] is applied to each of the K2/12 subgroups such that:
πintermediate4(i)=πintermediate32((j−1)×12+π124(R12[i])),
i=K1, . . . ,(K1+K2)−1,
Third, πintermediate33 is divided into K3/12 subgroups, and the subpermutation mask π125=[10, 0, 9, 1, 11, 7, 3, 5, 8, 6, 2, 4] is applied to each of the K3/12 subgroups, such that:
πintermediate4(i)=πintermediate33((j−1)×12+π125(R12[i])),
i=(K1+K2), . . . ,(K1+K2+K3)−1,
Fourth, πintermediate34 is divided into K4/12 subgroups, and the subpermutation mask π126=[9, 7, 2, 4, 10, 8, 3, 6, 11, 1, 5, 0] is applied to each of the K4/12 subgroups, such that:
πintermediate4(i)=πintermediate34((j−1)×12+π126(R12[i])),
i=(K1+K2+K3), . . . ,N−1,
As shown in
π(i)=πintermediate3(πintermediate4(i)),
i=0,1, . . . ,N−1.
Employing the foregoing methodology of this embodiment, for a given N, the interleaver may be implemented algebraically simply by specifying the subpermutation masks and the six parameters s, p, N1, K1, K2 and K3.
Interleaver Parameter Table:
The following table lists the values of s, p, N1, K1, K2 and K3 for various embodiments of the interleaver design process for different codeblock lengths.
The computer system 1100 may be coupled via the bus 1101 to a display 1111, such as a cathode ray tube (CRT), liquid crystal display, active matrix display, or plasma display, for displaying information to a computer user. An input device 1113, such as a keyboard including alphanumeric and other keys, is coupled to the bus 1101 for communicating information and command selections to the processor 1103. Another type of user input device is cursor control 1115, such as a mouse, a trackball, or cursor direction keys for communicating direction information and command selections to the processor 1103 and for controlling cursor movement on the display 1111.
According to one embodiment of the invention, generation and operation of interleaver designs in accordance with exemplary embodiments is provided by the computer system 1100 in response to the processor 1103 executing an arrangement of instructions contained in main memory 1105. Such instructions can be read into main memory 1105 from another computer-readable medium, such as the storage device 1109. Execution of the arrangement of instructions contained in main memory 1105 causes the processor 1103 to perform the process steps described herein. One or more processors in a multi-processing arrangement may also be employed to execute the instructions contained in main memory 1105. In alternative embodiments, hard-wired circuitry may be used in place of or in combination with software instructions to implement the embodiment of the present invention. Thus, embodiments of the present invention are not limited to any specific combination of hardware circuitry and software.
The computer system 1100 also includes a communication interface 1117 coupled to bus 1101. The communication interface 1117 provides a two-way data communication coupling to a network link 1119 connected to a local network 1121. For example, the communication interface 1117 may be a digital subscriber line (DSL) card or modem, an integrated services digital network (ISDN) card, a cable modem, or a telephone modem to provide a data communication connection to a corresponding type of telephone line. As another example, communication interface 1117 may be a local area network (LAN) card (e.g. for Ethernet™ or an Asynchronous Transfer Model (ATM) network) to provide a data communication connection to a compatible LAN. Wireless links can also be implemented. In any such implementation, communication interface 1117 sends and receives electrical, electromagnetic, or optical signals that carry digital data streams representing various types of information. Further, the communication interface 1117 can include peripheral interface devices, such as a Universal Serial Bus (USB) interface, a PCMCIA (Personal Computer Memory Card International Association) interface, etc.
The network link 1119 typically provides data communication through one or more networks to other data devices. For example, the network link 1119 may provide a connection through local network 1121 to a host computer 1123, which has connectivity to a network 1125 (e.g. a wide area network (WAN) or the global packet data communication network now commonly referred to as the “Internet”) or to data equipment operated by service provider. The local network 1121 and network 1125 both use electrical, electromagnetic, or optical signals to convey information and instructions. The signals through the various networks and the signals on network link 1119 and through communication interface 1117, which communicate digital data with computer system 1100, are exemplary forms of carrier waves bearing the information and instructions.
The computer system 1100 can send messages and receive data, including program code, through the network(s), network link 1119, and communication interface 1117. In the Internet example, a server (not shown) might transmit requested code belonging to an application program for implementing an embodiment of the present invention through the network 1125, local network 1121 and communication interface 1117. The processor 1103 may execute the transmitted code while being received and/or store the code in storage device 239, or other non-volatile storage for later execution. In this manner, computer system 1100 may obtain application code in the form of a carrier wave.
The term “computer-readable medium” as used herein refers to any medium that participates in providing instructions to the processor 1103 for execution. Such a medium may take many forms, including but not limited to non-volatile media, volatile media, and transmission media. Non-volatile media include, for example, optical or magnetic disks, such as storage device 1109. Volatile media include dynamic memory, such as main memory 1105. Transmission media include coaxial cables, copper wire and fiber optics, including the wires that comprise bus 1101. Transmission media can also take the form of acoustic, optical, or electromagnetic waves, such as those generated during radio frequency (RF) and infrared (IR) data communications. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD ROM, CDRW, DVD, any other optical medium, punch cards, paper tape, optical mark sheets, any other physical medium with patterns of holes or other optically recognizable indicia, a RAM, a PROM, and EPROM, a FLASH EPROM, any other memory chip or cartridge, a carrier wave, or any other medium from which a computer can read.
Various forms of computer-readable media may be involved in providing instructions to a processor for execution. For example, the instructions for carrying out at least part of the present invention may initially be borne on a magnetic disk of a remote computer. In such a scenario, the remote computer loads the instructions into main memory and sends the instructions over a telephone line using a modem. A modem of a local computer system receives the data on the telephone line and uses an infrared transmitter to convert the data to an infrared signal and transmit the infrared signal to a portable computing device, such as a personal digital assistance (PDA) and a laptop. An infrared detector on the portable computing device receives the information and instructions borne by the infrared signal and places the data on a bus. The bus conveys the data to main memory, from which a processor retrieves and executes the instructions. The instructions received by main memory may optionally be stored on storage device either before or after execution by processor.
In one embodiment, the chip set 1200 includes a communication mechanism such as a bus 1201 for passing information among the components of the chip set 1200. A processor 1203 has connectivity to the bus 1201 to execute instructions and process information stored in, for example, a memory 1205. The processor 1203 may include one or more processing cores with each core configured to perform independently. A multi-core processor enables multiprocessing within a single physical package. Examples of a multi-core processor include two, four, eight, or greater numbers of processing cores. Alternatively or in addition, the processor 1203 may include one or more microprocessors configured in tandem via the bus 1201 to enable independent execution of instructions, pipelining, and multithreading. The processor 1203 may also be accompanied with one or more specialized components to perform certain processing functions and tasks such as one or more digital signal processors (DSP) 1207, and/or one or more application-specific integrated circuits (ASIC) 1209. A DSP 1207 typically is configured to process real-world signals (e.g., sound) in real time independently of the processor 1203. Similarly, an ASIC 1209 can be configured to performed specialized functions not easily performed by a general purposed processor. Other specialized components to aid in performing the inventive functions described herein include one or more field programmable gate arrays (FPGA) (not shown), one or more controllers (not shown), or one or more other special-purpose computer chips.
The processor 1203 and accompanying components have connectivity to the memory 1205 via the bus 1201. The memory 1205 includes both dynamic memory (e.g., RAM) and static memory (e.g., ROM) for storing executable instructions that, when executed by the processor 1203 and/or the DSP 1207 and/or the ASIC 1209, perform the process of exemplary embodiments as described herein. The memory 1205 also stores the data associated with or generated by the execution of the process.
In the preceding specification, various embodiments have been described with reference to the accompanying drawings. It will, however, be evident that various modifications and changes may be made thereto, and additional embodiments may be implemented, without departing from the broader scope of the invention as set forth in the claims that follow. The specification and drawings are accordingly to be regarded in an illustrative rather than restrictive sense.
This application claims priority under 35 U.S.C. §119 based on U.S. Provisional Application Ser. No. 61/382,125, filed Sep. 13, 2010, the disclosure of which is incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6266795 | Wei | Jul 2001 | B1 |
6473878 | Wei | Oct 2002 | B1 |
6625762 | Le Dantec | Sep 2003 | B1 |
6910110 | Kim et al. | Jun 2005 | B2 |
7505526 | Coffey et al. | Mar 2009 | B2 |
7673213 | Chugg et al. | Mar 2010 | B2 |
7945001 | Ha et al. | May 2011 | B2 |
7958425 | Chugg et al. | Jun 2011 | B2 |
20090113271 | Bae et al. | Apr 2009 | A1 |
20100169722 | Wu et al. | Jul 2010 | A1 |
Number | Date | Country |
---|---|---|
2 043 290 | Apr 2007 | EP |
WO 2007045642 | Apr 2007 | WO |
Entry |
---|
Digital Video Broadcasting (DVB); Second Generation DVB Interactive Satellite System; Part 2: Lower Layers for Satellite Standard, XP-002665422, Mar. 2011, pp. 1-6. |
European Search Report for EP Application No. 11181137.8-2223 dated Dec. 28, 2011, pp. 1-11. |
Park, S., et al. “Interleaver Optimization of Convolutional Turbo Code for 802.16 Systems” IEEE Communications Letters, vol. 13, No. 5, May 2009, pp. 1-3. |
Number | Date | Country | |
---|---|---|---|
20120124453 A1 | May 2012 | US |
Number | Date | Country | |
---|---|---|---|
61382125 | Sep 2010 | US |