The disclosure relates to communication systems, and more particularly to communicating data over a communication channel.
A transmitter can transmit a signal to a receiver over a communication channel. The signal can encode various data. If the communication channel is not perfect, then the signal received by the receiver may not be identical to the signal transited by the transmitter. For instance, the communication channel may have introduced noise into the signal. If the signal received by the receiver is distorted enough by the communication channel, then the data may not be recoverable by the receiver.
Embodiments of the disclosure will now be described with reference to the attached drawings in which:
It should be understood at the outset that although illustrative implementations of one or more embodiments of the present disclosure are provided below, the disclosed systems and/or methods may be implemented using any number of techniques, whether currently known or in existence. The disclosure should in no way be limited to the illustrative implementations, drawings, and techniques illustrated below, including the exemplary designs and implementations illustrated and described herein, but may be modified within the scope of the appended claims along with their full scope of equivalents.
For some applications such as high-speed communication over short-reach links, the complexity and associated high latency provided by existing modulators may be unsuitable. According to an aspect, the present disclosure provides a modulator that can reduce latency for applications such as 40G/100G communication over copper cables or SMF (single-mode fiber). The modulator has a symbol mapper for mapping a bit stream into symbols, and a multi-level encoder including an inner encoder and an outer encoder for encoding only a portion of the bit stream. In some implementations, the multi-level encoder is configured such that an information block size of the inner encoder is small and matches a field size of the outer encoder. Therefore, components that would be used to accommodate larger block sizes can be omitted. The effect is that complexity and latency can be reduced. According to another aspect, the present disclosure provides a demodulator that is complementary to the modulator.
Other aspects and features of the present disclosure will become apparent, to those ordinarily skilled in the art, upon review of the following description of the specific embodiments of the invention.
If a signal received by a receiver is distorted enough by a communication channel, then data sent with the signal may not be recoverable by the receiver. FEC (forward error correction) or channel coding is a technique that involves encoding a signal in a redundant manner so that data sent with the signal may be recoverable even if there are errors in transmission. Such techniques may be employed when it is difficult or impractical to support re-transmission of data following an error. Example encoders are described below with reference to
Referring first to
The binary encoder 100 allows for adequate FEC capabilities. However, the binary encoder 100 is not very efficient at utilizing bandwidth of a communication channel. In the foregoing example with the rate=⅓, it can be seen that two-thirds of the bits transmitted over the communication channel are redundant. Reducing the rate to ½ reduces the amount of redundant bits, but if any one bit of the encoded bit stream is changed during transmission, then it may not be possible to recover the initial bit stream because there would be only one recovered copy of the initial bit stream against one bad copy of the initial bit stream and the receiver may not know which is the recovered copy.
The binary encoder 100 is rather rudimentary because the encoded bit stream n is merely made up of exact copies of the initial bit stream k. If the encoded bit stream n is transmitted over a communication channel that tends to cause an error for a certain bit pattern, then the redundancy provided by the encoded bit stream n may be inadequate (i.e. the same error may affect all copies of the initial bit stream k). In such scenarios, increasing redundancy provided by the binary encoder 100 may not help.
Referring now to
V
1
=u[n]+u[n−2]+u[n−3] [1]
V
2
=u[n−1]+u[n−2] [2]
Of course different delay elements 211,212,213 and different connections with the summation elements 221,222 would provide different outputs V1 and V2.
In the illustrated example, the convolutional encoder 200 has a rate of ½ because there are two outputs V1 and V2 for one input u. Other rates are possible for example by increasing the number of outputs. In contrast with the binary encoder 100 shown in
The binary encoder 100 shown in
Referring now to
Referring now to
The encoder 320 of the trellis-coded modulator 300 shown in
Referring now to
When each symbol transmitted by the trellis-coded modulator 300 is received at a receiver (not shown), the symbol may be demapped and decoded in a manner that is complemetary to the trellis-coded modulator 300. In this regard, the receiver may include a demapper for demapping the symbols, a deconvolution block for decoding the bits that have been encoded using the convolutional code 323, and another decoder block for decoding the bits that have been encoded using the block code 321. The manner in which this is accomplished is implementation-specific.
If there is an error during transmission, then the deconvolution block may perpetuate such error from one bit to other neighbouring bits. This is a by-product of the nature of convolution and deconvolution. If many errors exist for one outer codeword (i.e. codeword from an outer encoder), then it may not be possible to recover that outer codeword. In order to address this issue, the trellis-coded modulator 300 and its corresponding receiver are designed to spread out the errors over many outer codewords so that ideally no single outer codeword contains more errors than can be corrected. This is made possible by the interleaver 322, which loads many outer codewords into memory, interleaves the outer codewords, and outputs interleaved outer codewords.
Example operation of the interleaver 322 will be depicted with example original outer codewords show in Table 1 and interleaved outer codewords shown in Table 2.
The interleaver 322 creates an interleaved codeword using the first bit of each original codeword, and repeats for the remaining bits.
When an error in transmission affects an interleaved outer codeword, the result is that the error may affect multiple original outer codewords being recovered. However, since the errors are spread out over many original outer codewords being recovered, it may still be possible to recover all original outer codewords. Therefore, the interleaver 322 plays a useful role in increasing the robustness of the trellis-coded modulator 300.
However, since the interleaver 322 loads many original outer codewords into memory before it can generate the interleaved outer codewords, the interleaver 322 introduces significant latency. Also, since the receiver would implement a de-interleaver that loads many interleaved outer codewords before it can try to recover the original outer codewords, the de-interleaver also introduces significant latency. Such latencies may be tolerable for some applications, but for some applications they are not. For instance, for high-speed 40G/100G communication over SMF, the significant latencies introduced by the interleaver 322 and the complementary de-interleaver are generally considered to be poor or impractical. Simply removing the interleaver 322 and the complementary de-interleaver may reduce the robustness of the trellis-coded modulator 300 and the receiver and therefore may not be a practical solution.
Referring now to
Therefore, with reference back to
In accordance with an embodiment of the disclosure, for the inner encoder 622, short codes with efficient trellis representations (e.g. single-parity-check, Hamming, and extended-Hamming codes) are used. An advantage of using short codes (instead of using a convolutional code as in the TCM 300 depicted by
The inner encoder 622 is positioned between the outer encoder 621 and the symbol mapper 610. Concatenation of multiple codes is a technique to construct a powerful code from simple components, while maintaining a relatively simple decoder. Furthermore, it allows codes with complementary properties to be combined into a single code. For example, the inner code is typically a code with an efficient soft-decision decoder, whereas the outer code is a code with an efficient hard-decision decoder. In the language of paragraph [0026], the inner code is said to have an efficient trellis representation, which implies an efficient soft-decision decoder.
In comparison with the trellis-coded modulator 300 depicted by
Various examples described herein refer to an “LSB sequence”, which is a term used to describe a sequence of bits where each bit is an LSB (i.e. b0) of a set of bits (e.g. (b2, b1, b0) for 8-PAM) that are mapped to a symbol. Thus, if an LSB sequence has 100 bits for example, the LSB sequence may be used to map 100 symbols. Typically a single LSB is used to select a class of symbols. However, in another embodiment, more than one bit could be used for this purpose. Thus, an “LSB sequence” could alternatively be a sequence of bits where each bit is a lower-significance subset (e.g. b0 or b1,) of a set of bits (e.g. (b2, b1, b0) for 8-PAM) that are mapped to a symbol.
According to the multi-level modulator 600 shown in
Note that defining the constellation with 8-PAM symbols is implementation-specific. In other implementations, 4-PAM symbols are used. In other implementations, 16-PAM symbols are used. More generally, any suitable constellation with 2N-PAM symbols may be employed. For 2N-PAM, each of the nRS·nB bits of the LSB sequence maps to the least significant bit (i.e. b0) in the label of a 2N-PAM symbol, with the overall label being (b0, b1, . . . , bN−1). A corresponding stream of (N−1)·nRS·nB most significant bits, mapped to (b1, b2, . . . , bN−1), are optionally encoded by the RS encoder 630. Note that the size of the constellation may be unrelated to the length of the block code. For instance, according to some implementations, only the LSB of the constellation (assuming PAM modulation) is encoded by an inner/outer encoder, regardless of the number of points in the constellation.
The non-LSB sequences may be encoded by a separate encoder 630, but this is completely optional because it may be easy for the receiver to decipher which symbol has been transmitted even when there are errors during transmission. This is because all symbols of a class selected by the LSB are separated from one another. The separate encoder 630 might for example be an RS encoder 630 as depicted, or some other encoder such as BCH encoder.
The multi-level modulator 600 is shown with two levels of encoding (i.e. the inner encoder 622 and the outer encoder 621). However, in alternative implementations, there are three or more levels of encoding. For example, a two-dimensional outer code could be used, where “codewords” are 2-D arrays of m-bit symbols, each row and column of the array being a valid codeword of an RS code. The two-dimensional codes may be referred to as “Product Codes”, and could be considered to be a two-level outer encoding. However, such alternative implementations with three or more levels of encoding might provide higher latency than two levels of encoding. More generally, the multi-level modulator 600 has at least two levels of encoding.
The multi-level modulator 600 can provide advantages with respect to latency and hardware complexity, which are two of the main challenges in designing FEC schemes for high-speed short-reach links. For instance, since the multi-level modulator 600 operates to confine errors to symbol boundaries with short codes, interleaving can be omitted thereby reducing hardware complexity and allowing lower latencies.
Note that the latencies can be designed. For example, by fixing the choice of the inner block code and the overall spectral efficiency, a range of latencies can be obtained by varying the (nRS, kRS=nRS−2tRS) of the RS encoder 621, where tRS is a maximum number of m-bit RS symbols that can have error. In each case, the field size is m=kB, and thus a single RS decoder can be designed (for the maximum tRS) that can be used for the entire range of latencies. For the specific case of a target spectral efficiency of 2.60 bits/symbol and a (nB=16, kB=11) extended-Hamming inner code, Table 3 gives the parameters of the RS encoder 621 for a range of latencies. Note that in each case, the field size of the RS encoder 621 is m=11.
Referring now to
It is to be understood that the field size of the outer encoder 621 being m=11 is very specific for exemplary purposes only. Other field sizes are possible and are within the scope of this disclosure. For example, in other implementations, the field size of the outer encoder 621 is m=9. Such implementations may for example use 5 parity bits (e.g. 14 bits total), or some other number of parity bits. The information block size of the inner encoder 622 may be kB=9 in the event that it is chosen to match the field size m of the outer encoder 621. In some implementations, the field size of the outer encoder 621 is M≧9, and the information block size of the inner encoder 622 is the same in the event that it is chosen to match the field size m of the outer encoder 621. Other implementations are possible.
The precise configuration of the multi-level modulator 600 would normally be static based on a hardware configuration of the multi-level modulator 600. However, in alternative implementations, the precise configuration of the multi-level modulator 600 can be dynamically changed. Dynamically changing the multi-level modulator 600 could for example allow the multi-level modulator 600 to accommodate for different latencies under different operating environments, etc.
Referring now to
However, in contrast with the multi-level modulator 600 shown in
For each 2N-PAM symbol in the stream, the non-LSB bits are obtained from a common stream of p·nRS·nB bits, which are optionally encoded by an RS encoder 930. Note that “p” is an average number of bits per LSB and is not necessarily an integer. For example, if half of the symbols are 4-PAM and the other half are 8-PAM, then p=(1+2)/2=1.5. The number of bits per LSB varies with N. In some implementations, the choice of N depends on a “bit-loading” algorithm, which selects N based on one or more criteria that may depend on modulation used.
The “variable” 2N-PAM modulation described with reference to
More specifically, in DMT, a frequency band is divided into M sub-channels. To achieve a desired rate of communication, L bits of information are transmitted per DMT symbol. A DMT symbol is effectively M PAM-N sub symbols, where Ni, i in [1,M], is chosen by the bit-loading algorithm. In order to transmit L bits of information, the bit-loading algorithm is constrained to find the Ni that result in a target value of “p” (the average number of bits per LSB), where this value is a function of the rates of the codes applied to the LSB and non-LSB sequences.
Note that a DMT transmitter does not actually sequentially transmit varying 2N-PAM symbols sequentially in time over a communication channel. Rather, it actually takes an IDFT (Inverse Discrete Fourier Transform) of the sequence of 2N-PAM symbols, and then transmits this resulting waveform over the communication channel. In doing so, it is doing frequency division multiplexing of many sub-channels, each sub-channel communicating a 2N-PAM modulation.
It is to be understood that the mapping of encoded bits to a “variable” 2N-PAM modulation is not specific to DMT, although DMT is an application where this may be useful. Note that the encoding of the LSB sequence may occur regardless of modulation utilised (e.g. 2N-PAM or DMT). However, the encoding of the non-LSB sequence may depend on the modulation utilised as described above. Also note that a PAM constellation may be used regardless of modulation scheme (e.g. PAM and DMT modulation).
Although not depicted, the present disclosure also includes a multi-level demodulator that is complementary to the multi-level modulator 600 shown in
Additional aspects are defined by the following clauses:
a symbol demapper for demapping symbols into a bit stream; and
a multi-level decoder comprising an inner decoder and an outer decoder for decoding only a portion of the bit stream such that an information block size of the inner decoder matches a field size of the outer decoder.
the bit stream further comprises a non-LSB sequence having (N-1)-times as many bits as the LSB sequence; and
the symbol demapper is configured for demapping the symbols from a constellation of 2N-PAM symbols into the bit stream, where N is an integer and is constant from symbol to symbol.
the bit stream further comprises a non-LSB sequence having p-times as many bits as the LSB sequence, where p is an average number of bits per LSB; and
the symbol demapper is configured for demapping the symbols from a constellation of 2N-PAM symbols into the bit stream, where N is an integer and is variable from symbol to symbol.
the inner decoder is a block decoder; and
the outer decoder is an RS (Reed-Solomon) decoder.
demapping symbols into the bit stream; and
a multi-level decoder comprising an inner decoder and an outer decoder decoding only a portion of the bit stream such that an information block size of the inner decoder matches a field size of the outer decoder.
a symbol demapper for demapping symbols into a bit stream, the bit stream comprising an LSB (Least Significant Bit) sequence; and
a multi-level decoder comprising an inner decoder and an outer decoder for decoding only the LSB sequence of the bit stream.
demapping symbols into the bit stream, the bit stream comprising an LSB (Least Significant Bit) sequence; and
a multi-level decoder comprising an inner decoder and an outer decoder decoding only the LSB sequence of the bit stream.
Numerous modifications and variations of the present disclosure are possible in light of the above teachings. It is therefore to be understood that within the scope of the appended claims, the disclosure may be practised otherwise than as specifically described herein.
This application is a continuation of U.S. patent application Ser. No. 14/744,015 filed on Jun. 18, 2015, which in turn is a continuation of U.S. patent application Ser. No. 14/180,315 filed on Feb. 13, 2014. This application claims priority from U.S. Provisional Patent Application No. 61/765,050 filed on Feb. 15, 2013. The aforementioned applications are incorporated by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
61765050 | Feb 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14744015 | Jun 2015 | US |
Child | 15206011 | US | |
Parent | 14180315 | Feb 2014 | US |
Child | 14744015 | US |