EP0166560B1 - Multi-dimensional coding for error reduction - Google Patents

Multi-dimensional coding for error reduction Download PDF

Info

Publication number
EP0166560B1
EP0166560B1 EP85304296A EP85304296A EP0166560B1 EP 0166560 B1 EP0166560 B1 EP 0166560B1 EP 85304296 A EP85304296 A EP 85304296A EP 85304296 A EP85304296 A EP 85304296A EP 0166560 B1 EP0166560 B1 EP 0166560B1
Authority
EP
European Patent Office
Prior art keywords
bits
dimensional code
code words
signals
binary
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired
Application number
EP85304296A
Other languages
German (de)
French (fr)
Other versions
EP0166560A2 (en
EP0166560A3 (en
Inventor
Arthur Robert Calderbank
Neil James Alexander Sloane
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
AT&T Corp
Original Assignee
American Telephone and Telegraph Co Inc
AT&T Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by American Telephone and Telegraph Co Inc, AT&T Corp filed Critical American Telephone and Telegraph Co Inc
Publication of EP0166560A2 publication Critical patent/EP0166560A2/en
Publication of EP0166560A3 publication Critical patent/EP0166560A3/en
Application granted granted Critical
Publication of EP0166560B1 publication Critical patent/EP0166560B1/en
Expired legal-status Critical Current

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L1/00Arrangements for detecting or preventing errors in the information received
    • H04L1/004Arrangements for detecting or preventing errors in the information received by using forward error control
    • H04L1/0056Systems characterized by the type of code used
    • H04L1/0059Convolutional codes
    • HELECTRICITY
    • H03ELECTRONIC CIRCUITRY
    • H03MCODING; DECODING; CODE CONVERSION IN GENERAL
    • H03M13/00Coding, decoding or code conversion, for error detection or error correction; Coding theory basic assumptions; Coding bounds; Error probability evaluation methods; Channel models; Simulation or testing of codes
    • H03M13/25Error detection or forward error correction by signal space coding, i.e. adding redundancy in the signal constellation, e.g. Trellis Coded Modulation [TCM]

Definitions

  • This invention relates to coding information so as to reduce errors caused by transmission from being included in the received signal and, in particular, to multi-dimensional coding.
  • the information signals are often distorted by noise and other causes. Sometimes the information signals are distorted to such an extent that the received signals do not duplicate the information sent.
  • the information is coded at the transmitter.
  • block coding introduces n-k redundant bits to a block of k bits of information to derive a coded block of n bits which is transmitted to a receiver.
  • code words there are 2 k code words, each of length n, and the set is called an (n, k) block code.
  • Convolutional coding introduces m bits from previous blocks of information, each having k bits, to derive a coded signal having n bits.
  • the encoder is said to have a memory order of m.
  • the set of codes is called an (n, k, m) convolutional code.
  • the code rate is k/n.
  • U. S. Patent No. 4,077,021 teaches a technique called set partitioning that assigns signal points to successive blocks of input data. More particularly, a code rate of 4 bits/2-dimensional symbol is shown. Also, a coding gain of 4 db over standard uncoded transmission is obtained. That is, noise immunity is obtained without increasing the power required for transmission. As will be described fully in the detailed description of the present invention, it is desirable to obtain a more efficient coding scheme.
  • a paper by A. Gersho and V.B. Lawrence in IEEE International Conference on Communications, Amsterdam, 14th-17th May 1984, vol. 1, pages 377-380, entitled "Multi-dimensional Signal Design for Digital Transmission over Bandlimited Channels” discloses a coding arrangement in which each word (of, say, eight bits) is divided into three groups of bits of variable length.
  • the first group which may contain from 2 to 4 bits, determines the numbers of bits in the other groups.
  • the first and second groups together address an unsigned four-dimensional code-word and the third group determines the signs of the non-zero components of the code-word.
  • This paper also discloses that a ROM table look-up can be used to assign a code-word to each word.
  • IBM Technical Disclosure Bulletin, vol. 26, no. 2, July 1983, pages 662-664 discloses a coding scheme in which a 6-bit word is divided into two groups, containing four and two bits respectively.
  • the two bits in the second group are expanded to three bits by an eight-state convolutional code (i.e. a convolutional code using three bits of memory).
  • the three bits of the expanded second group are used to specify one of eight subsets into which a two-dimensional constellation of 128 points is divided, and the four bits of the first group are used to determine which point within the specified subset is used.
  • the invention as claimed in claims 1 and 4 provides a coding apparatus and method respectively which 1) reduces the power consumed, 2) achieves a high code rate, and 3) achieves efficiency in terms of low power use and low error in the received signal.
  • an information block comprising eight bits of input to the coder is converted into any one of five hundred and twelve four-dimensional code words.
  • the eight bits are changed into an output having nine bits by retaining two input bits from the immediately preceding block and one input bit from two preceding blocks.
  • the output is divided into two signal groups: a first group comprises five bits and a second comprises four bits.
  • the numbers appearing in the thirty-two code words include 1, -1, 3, -3, 5 and -5.
  • the second group of four bits makes up a vector which determines the sign of the four-dimensional code word read from the read only memory.
  • a trellis code with rate of eight bits per four-dimensional symbol with a gain of 4.7 decibels over standard uncoded transmission corresponds to improving the block error rate by a factor of 10.
  • the signal constellation comprises five hundred twelve four-dimensional signal points, that is, each symbol has a set of four numbers which defines a signal point in four-dimensional space.
  • a trellis code with rate twelve bits per four-dimensional symbol provides a gain of 4.9 db over standard uncoded transmission. This method is suggested for data transmission rates of 14.4 kbits/sec.
  • FIG. 1 there is shown a prior art system comprising a digital source 10 supplying a signal to encoder 12.
  • the coded signal from encoder 12 is modulated by device 14 for transmission to a distant location where the signal is demodulated at device 18.
  • the demodulated signal is thereafter decoded at device 20 and sent on to a digital sink 22.
  • the use of encoder 12 reduces the errors caused by noise in the transmission facility 16.
  • the present invention relates to an improvement in the aforesaid encoder 12.
  • the three bits shown at time i are the bits stored for a 2 at time (i-1), that is, a i 2 -1 ; for a3 at time (i-1), that is, a i 3 -1 ; and a3 at time (i-2), that is, a3 -2 .
  • An edge joins two states at time i and i + 1. Each edge is double in this case, as will be explained below, but only shown drawn singly to simplify the drawing.
  • the state transition diagram can be understood by examining, for example, the transition from the state '010' at time i to a state at time i + 1.
  • the 1 in state '010' is a3 -1
  • this i the 1 in state '010' is a i 3 -1
  • this bit 1 will now be a3 -2 and can be any one of the four codes which end in a 1 : 001, 101, 011, or 111 depending on the next value of a i 2 -1 and a i 3 -a i 3 -1 .
  • the noise samples z ij are independent zero-mean Gaussian variables of variance, ⁇ 2 .
  • the Viterbi algorithm disclosed at 61 Proceedings of the IEEE 268-278 (No. 3, March 1973), is used to find the most likely path through the trellis given the observed sequence ⁇ r i ⁇ .
  • the path chosen will not always coincide with the correct path, but will occasionally diverge from it and remerge at a later time. This is called an error event.
  • An error event E of length 1 lasts from j to (j+I), the sequence j , ..., (j+l-1) instead of the correct sequence x i , ... , x (j+l-1) .
  • the squared Euclidean distance d 2 that is, d 2 (E), between the two paths of E is given by where denotes the usual Euclidean norm.
  • FIG. 5 Basic to the trellis codes of the embodiment disclosed hereinbelow is a rate 3/4 binary convolutional code with a total memory 3 and free distance 4.
  • FIG. 5 A portion of the encoder is shown in FIG. 5 which has been disclosed in the aforesaid Lin book at page 292.
  • the possible transitions between states of such an encoder is shown hereinabove in FIG. 3.
  • the minimum squared distance of this trellis code is simply four times the free distance of the original binary convolutional code, namely 16. This is so because 0 opposite 1 contributes 1 to the free distance while 1 opposite -1 contributes 4 to the squared minimum distance.
  • the average power or energy is
  • the first column of Table 1 shows the code words representative of signal points in four dimensional space.
  • the number of permutations for each representative code word is shown in column three, giving a total of thirty-two code words stored in ROM 74.
  • the list of thirty-two code words is obtained by permuting the coordinates of the code words in column one.
  • the second set of leads 51 from serial to parallel converter 70 carries three of the binary input bits to a device 50 which stores three bits from prior blocks as disclosed in detail earlier herein with reference to FIG. 5, and delivers four bits on leads 53 to a device 80.
  • the binary bit 0 is converted to 1 and a binary 1 is converted to a -1.
  • the vector W of four bits W i , W 2 , W s , and W 4 are then delivered to multipliers 82 ... 88.
  • the amber y 1 of the accessed code word is then multiplied by W 1 from lead 81 at multiplier 82 to generate output x i .
  • x 2 , x s , and x 4 are generated and sent over leads 89.
  • the thirty-two code words correspond to the entries in ROM 74. The entire list of thirty-two code words in ROM 74 is shown in Table 2 hereinbelow.
  • the set of coordinates (x 1 , x 2 , x 3 , x 4 ) representing the input block of 8 bits on leads 89 is then sent on to a modulator.
  • the present invention relates to an encoder only and therefore other equipment cooperating with the encoder is not disclosed in any detail, beyond what was disclosed earlier with reference to FIG. 1.
  • the distance d( A, B ) between two sets of vectors A and B is given by the expression:
  • the partition into sets S( w ) satifies the following metric properties:
  • the properties (M1) and (M2) guarantee that the squared distance of any error event is at least 16.
  • the properties (M2) implies that the minimum squared distance of the high-rate code is at least 16.
  • the average signal power P of the 512 point signal constellation is given by the expression:
  • FIG. 8 there is shown a signal constellation comprising sixty-four signal points which is used for standard uncoded transmission at the rate of 6 bits/2-dimensional symbol.
  • a constellation comprising two such copies are needed.
  • the average signal power thus,
  • Coded transmission requires 2 (k+1) signal points.
  • the 2 k+1 signal points are obtained by taking all points of energy four, twelve, twenty, ... and just enough points of a final shell to bring the total number up to 2 k+1 .
  • Edges in the eight state trellis originally labelled + w are now labelled with the 2 k-2 vectors in S(w) U S(-w).
  • the metric properties (M1) and (M2) guarantee that the minimum squared distance of this trellis code is sixteen.
  • the scheme disclosed by the present invention is an efficient method of coding.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • Probability & Statistics with Applications (AREA)
  • Theoretical Computer Science (AREA)
  • Error Detection And Correction (AREA)
  • Digital Transmission Methods That Use Modulated Carrier Waves (AREA)
  • Compression, Expansion, Code Conversion, And Decoders (AREA)

Description

    Technical Field
  • This invention relates to coding information so as to reduce errors caused by transmission from being included in the received signal and, in particular, to multi-dimensional coding.
  • Background of the Invention
  • When information is sent from a transmitter over a-channel to a receiver, the information signals are often distorted by noise and other causes. Sometimes the information signals are distorted to such an extent that the received signals do not duplicate the information sent.
  • In order to reduce errors in the received signals, the information is coded at the transmitter. There are two basic coding schemes: block coding and convolution coding. These coding schemes are explained in detail in a book entitled "Error Control Coding: Fundamentals and Applications" by S. Lin et al.
  • Simply stated, block coding introduces n-k redundant bits to a block of k bits of information to derive a coded block of n bits which is transmitted to a receiver. For binary signals, there are 2k code words, each of length n, and the set is called an (n, k) block code. Convolutional coding introduces m bits from previous blocks of information, each having k bits, to derive a coded signal having n bits. The encoder is said to have a memory order of m. The set of codes is called an (n, k, m) convolutional code. The code rate is k/n.
  • U. S. Patent No. 4,077,021 teaches a technique called set partitioning that assigns signal points to successive blocks of input data. More particularly, a code rate of 4 bits/2-dimensional symbol is shown. Also, a coding gain of 4 db over standard uncoded transmission is obtained. That is, noise immunity is obtained without increasing the power required for transmission. As will be described fully in the detailed description of the present invention, it is desirable to obtain a more efficient coding scheme.
  • A paper by A. Gersho and V.B. Lawrence in IEEE International Conference on Communications, Amsterdam, 14th-17th May 1984, vol. 1, pages 377-380, entitled "Multi-dimensional Signal Design for Digital Transmission over Bandlimited Channels" discloses a coding arrangement in which each word (of, say, eight bits) is divided into three groups of bits of variable length. The first group, which may contain from 2 to 4 bits, determines the numbers of bits in the other groups. The first and second groups together address an unsigned four-dimensional code-word and the third group determines the signs of the non-zero components of the code-word. This paper also discloses that a ROM table look-up can be used to assign a code-word to each word.
  • IBM Technical Disclosure Bulletin, vol. 26, no. 2, July 1983, pages 662-664 discloses a coding scheme in which a 6-bit word is divided into two groups, containing four and two bits respectively. The two bits in the second group are expanded to three bits by an eight-state convolutional code (i.e. a convolutional code using three bits of memory). The three bits of the expanded second group are used to specify one of eight subsets into which a two-dimensional constellation of 128 points is divided, and the four bits of the first group are used to determine which point within the specified subset is used.
  • Summary of the Invention
  • The invention as claimed in claims 1 and 4 provides a coding apparatus and method respectively which 1) reduces the power consumed, 2) achieves a high code rate, and 3) achieves efficiency in terms of low power use and low error in the received signal.
  • More particularly, according to one embodiment of the present invention, an information block comprising eight bits of input to the coder is converted into any one of five hundred and twelve four-dimensional code words. The eight bits are changed into an output having nine bits by retaining two input bits from the immediately preceding block and one input bit from two preceding blocks. The output is divided into two signal groups: a first group comprises five bits and a second comprises four bits.
  • The first group having five uncoded bits, addresses any one of thirty-two (25 = 32) locations of a read only memory. Each location has a code word comprising four numbers, representing the coordinates of a point in four-dimensional space. The numbers appearing in the thirty-two code words include 1, -1, 3, -3, 5 and -5. These code words are shown in tables 1 and 2, included in the detailed description of the invention hereinbelow.
  • The second group of four bits makes up a vector which determines the sign of the four-dimensional code word read from the read only memory. This scheme is equivalent to having the code word read from any page of a code book having sixteen (24 = 16) pages, each page having thirty-two code words entered therein.
  • Thus, there is disclosed a trellis code with rate of eight bits per four-dimensional symbol with a gain of 4.7 decibels over standard uncoded transmission. This 0.7 decibel increase over the aforesaid prior art code systems corresponds to improving the block error rate by a factor of 10. The signal constellation comprises five hundred twelve four-dimensional signal points, that is, each symbol has a set of four numbers which defines a signal point in four-dimensional space.
  • By way of comparison, first, transmission of two consecutive two-dimensional signals using one of the prior art codes with rate four bits per two-dimensional symbol would require the equivalent of 1, 024 because 322 = 1024 ) four-dimensional signal points. That is, the size of the code is reduced. Second, the restriction of the five hundred twelve point constellation to the first two coordinates, or to the last two coordinates, requires only a set of thirty-two signal points. This code rate of eight bits per four-dimensional symbol is suggested for data transmission rates of 9.6 kbits/sec.
  • In another embodiment of the present invention, a trellis code with rate twelve bits per four-dimensional symbol provides a gain of 4.9 db over standard uncoded transmission. This method is suggested for data transmission rates of 14.4 kbits/sec.
  • In the limit, when the number, k, of bits in a block approaches infinity, the coding gain is asymptotic to 4.9715 decibels. That is, the difference between the limiting gain and that provided with k = 12 is very small.
  • Brief Description of the Drawing
    • FIG. 1 is a prior art system for transmission of encoded signals;
    • FIG. 2 illustrates the concept of convolutional encoders;
    • FIG. 3 shows possible transitions of states between two instants in time;
    • FIG. 4 illustrates error events and the term Euclidean distance;
    • FIG. 5 shows a convolutional encoder of memory order three;
    • FIG. 6 shows a signal constellation for uncoded transmission at the rate four bits per two dimensional symbol;
    • FIG. 7 shows a convolutional encoder embodying the present invention;
    • FIG. 8 shows a rectangular constellation for uncoded transmission at six bits per two dimensional symbol; and
    • FIG. 9 shows a signal constellation for trellis codes at the rate four bits per two dimensional symbol.
    Detailed Description
  • Referring to FIG. 1, there is shown a prior art system comprising a digital source 10 supplying a signal to encoder 12. The coded signal from encoder 12 is modulated by device 14 for transmission to a distant location where the signal is demodulated at device 18. The demodulated signal is thereafter decoded at device 20 and sent on to a digital sink 22. The use of encoder 12 reduces the errors caused by noise in the transmission facility 16. The present invention relates to an improvement in the aforesaid encoder 12.
  • It is necessary to disclose the theoretical basis for the present invention in order to fully appreciate it. Assume that an input block of k bits from a serial bit stream is first converted by a series-to-parallel converter such as device 70 in FIG. 7, such converters being well known, to an input of k parallel bits {ai 1 1, {ai 2 }, {ai 3 }, ..., {ai K} prior to
    • entering the encoder at time i. Assume further that the output of the encoder, at time i, is x' and depends not only on the present value of the input sequence but also on the previous vi≧0 bits as illustrated in FIG. 2. That is, the encoder is a convolutional encoder as well as a block encoder. If vj = 0 then {a is said to be a sequence of uncoded bits. The constraint length v is given by
      Figure imgb0001
    • The output x' of the encoder is a fixed function x of the (v + k) variables
      Figure imgb0002
      That is,
      Figure imgb0003
      The
      Figure imgb0004
      is the state of the encoder and there are 2v states.
  • Referring to FIG. 3, there is shown a state transition diagram from time i to time (i + 1) for a trellis code with k = 3, v1 = 0, v2 = 1, and v3 = 2. Looking briefly ahead to FIG. 5, there is shown a coder, which is an application of FIG. 2, where the ai 1 sequence has no memory, that is, v1 = 0, or uncoded; where a1 2 sequence has one bit of memory, that is, v2 = 1; and, where the ai 3 sequence has two bits of memory, that is, v3 = 2. Because three bits of memory exist, there are (23 = 8) eight states for the coder. The three bits shown at time i are the bits stored for a2 at time (i-1), that is, ai 2 -1; for a3 at time (i-1), that is, ai 3 -1; and a3 at time (i-2), that is, a3 -2. An edge joins two states at time i and i + 1. Each edge is double in this case, as will be explained below, but only shown drawn singly to simplify the drawing.
  • The state transition diagram can be understood by examining, for example, the transition from the state '010' at time i to a state at time i + 1. Remembering that at time i the 1 in state '010' is a3 -1, at time i + 1 this i the 1 in state '010' is ai 3 -1, at time i + 1 this bit 1 will now be a3 -2 and can be any one of the four codes which end in a 1 : 001, 101, 011, or 111 depending on the next value of ai 2 -1 and ai 3 -ai 3 -1.
  • Returning to the theoretical basis, noise in the transmission channel distorts the sequence of signals from the output of the coder:
    Figure imgb0005
    Then, the signal received say at decoder 20 of FIG. 1, is:
    Figure imgb0006
    where rij = xij + zij, the zij being the noise component. The noise samples zij are independent zero-mean Gaussian variables of variance, σ2.
  • The Viterbi algorithm, disclosed at 61 Proceedings of the IEEE 268-278 (No. 3, March 1973), is used to find the most likely path through the trellis given the observed sequence ∥ri∥. The path chosen will not always coincide with the correct path, but will occasionally diverge from it and remerge at a later time. This is called an error event.
  • An error event E of length 1 lasts from j to (j+I), the sequence j, ..., (j+l-1) instead of the correct sequence xi , ... , x(j+l-1). The squared Euclidean distance d2, that is, d2(E), between the two paths of E is given by
    Figure imgb0007
    where
    Figure imgb0008
    denotes the usual Euclidean norm.
  • Referring to FIG. 4, there is shown an error event for which the squared Euclidean distance is
    Figure imgb0009
    The average transmitted power is given by
    Figure imgb0010
  • For small noise variance a2, the minimum distance dmin over all error events determines the probability of error. The figure of merit for a trellis code is the normalized minimum distance stated by the ratio:
    Figure imgb0011
    The bigger this ratio, the better the code. The performance of a coding scheme is measured against that of uncoded transmission at the same rate. The coding gain in decibels, db, is given by the expression:
    Figure imgb0012
  • Basic to the trellis codes of the embodiment disclosed hereinbelow is a rate 3/4 binary convolutional code with a total memory 3 and free distance 4. A portion of the encoder is shown in FIG. 5 which has been disclosed in the aforesaid Lin book at page 292. The three parallel input sequences ai 1, ai 2 and a3 determine the output sequence v = (vi 1 , vi 2, vi 3, vi 4) according to the rules:
    Figure imgb0013
    Figure imgb0014
    Figure imgb0015
    and
    Figure imgb0016
    The
    Figure imgb0017
    describe the state of the encoder. The possible transitions between states of such an encoder is shown hereinabove in FIG. 3. The edge joining state ai 2 -1 ai 3 -1 a3 -2 to state ai 2 a3 ai-1 3 can be labelled with the outputs:Vi = (vi 1,vi 2,vi 3vi 4) and i = (i 1, i 2, i 3, i 4) corresponding to this transition so that
    Figure imgb0018
    Figure imgb0019
    and
    Figure imgb0020
    The binary notation 0,1 is then changed to 1, -1, respectively. An edge joining two states is then labelled with a pair of vectors ( w1, w2, w3, l w4) and ( -w1, -w2, -W3, -w4 ) where w = ±1 and i = 1, 2, 3, and 4. This defines a trellis encoder with rate 3 bits/ 4-dimensional symbol. The minimum squared distance of this trellis code is simply four times the free distance of the original binary convolutional code, namely 16. This is so because 0 opposite 1 contributes 1 to the free distance while 1 opposite -1 contributes 4 to the squared minimum distance.
  • Thus far, a trellis code at the low rate 3 bits/4-dimensional symbol was disclosed. Transmission at higher rates, say 8 bits/4-dimensional symbol or 12 bits/4-dimensional symbol requires more channel symbols. Indeed, as is readily apparent from the disclosure thus far, in order to achieve any coding gain, more symbols are needed than for uncoded transmission at the same rate.
  • Referring to FIG. 6, there is shown a rectangular constellation comprising sixteen ( 24 = 16) signal points for standard uncoded transmission, of binary input, at the rate of 4 bits/ 2-dimensional symbol. For uncoded transmission of a 4-dimensional symbol, two copies of the constellation shown in FIG. 6 are needed, yielding 256 ( 16 x 16 = 256 ) possible signals. Using the formula developed earlier herein, the average power or energy is
  • Figure imgb0021
    that is, 20. Because the minimum squared distance between distinct signals is four, the figure of merit is given by the formula:
    Figure imgb0022
  • For coded transmission, however, 512 signal points are used, namely, twice the signal constellation for uncoded transmission of 4-dimensional symbols. This is so because a block of eight input bits is converted to nine bits using three bits from prior blocks and 29 is 512. This conversion will become clear by referring to FIG. 7, wherein is shown a stream of binary bits on lead 71 converted from serial to parallel in converter 70 and then sent on via two sets of leads 73 and 51.
  • The first set of leads 73 carries five uncoded bits which are converted from binary form by changing a 0 to a 1 and a 1 to a -1 in a binary converter 72 and then sent on via leads 75 to address any one of thirty-two ( 25 = 32 ) code words, representing signal points, from a storage device such as read only memory ( ROM ) 74. Because each code word defines a point in four dimensional space, four numbers are required for each code word. The numbers of the addressed code word are passed via leads 77 to multipliers 82 ... 88. Representative signal points are shown in Table 1 hereinbelow.
    Figure imgb0023
  • The first column of Table 1 shows the code words representative of signal points in four dimensional space. The number of permutations for each representative code word is shown in column three, giving a total of thirty-two code words stored in ROM 74. The list of thirty-two code words is obtained by permuting the coordinates of the code words in column one.
  • The second set of leads 51 from serial to parallel converter 70 carries three of the binary input bits to a device 50 which stores three bits from prior blocks as disclosed in detail earlier herein with reference to FIG. 5, and delivers four bits on leads 53 to a device 80. At device 80 the binary bit 0 is converted to 1 and a binary 1 is converted to a -1. The vector W of four bits Wi, W2, Ws, and W4 are then delivered to multipliers 82 ... 88. The amber y1 of the accessed code word is then multiplied by W1 from lead 81 at multiplier 82 to generate output xi. Likewise, x2, xs, and x4 are generated and sent over leads 89.
  • Because there are four bits W1 , W2, W3, and W4, and because there are two values 1 or -1 for each, together there can be sixteen (24 = 16 ) different permutations of these bits. Because there are thirty-two signal points ( x1 x2 , x3 x4) in the set S(w) which satisfy the requirement xi = wi (mod 4), for i = 1, 2, 3, and 4, there are 512 ( 16 x 32 = 512 ) symbols in the signal constellation, because all permutations are allowed. Thus, the coding scheme of the present invention can be thought of as a code book comprising sixteen pages with thirty-two code words on each page. Each page corresponds to the vector Wi, where i = 1, 2, 3, and 4. The thirty-two code words correspond to the entries in ROM 74. The entire list of thirty-two code words in ROM 74 is shown in Table 2 hereinbelow.
    Figure imgb0024
    Figure imgb0025
    Figure imgb0026
  • The set of coordinates (x1, x2, x3, x4) representing the input block of 8 bits on leads 89 is then sent on to a modulator. The present invention relates to an encoder only and therefore other equipment cooperating with the encoder is not disclosed in any detail, beyond what was disclosed earlier with reference to FIG. 1.
  • The distance d( A, B ) between two sets of vectors A and B is given by the expression:
    Figure imgb0027
    The partition into sets S( w ) satifies the following metric properties:
    • (M1): if x, y ∈ S( w ), then ∥x-y∥2 ≧ 16; and
    • (M2): if v ≠ w, then d2(S(v), S(w)) = ∥ v-w ∥2.

    To verify (M1), let x = (xi, X2, X3, X4,) and y = (y1, y2, y3, y4 ). Then Xi ≠ yi for some i. Since xi≡yi(mod 4), we have ∥x-y ∥16. To verify (M2), let x = (xi, x2 x3, x4) ∈ S(v), and y = (y1, y2, y3, y4) ∈ S(w). If xi≢yi(mod 4), then |xi -yi|2 ≧ 4. Hence ∥x - y ∥2 ≧ ∥v - w∥2 and the equality holds when x = v and y = w.
  • Earlier hereinabove, a trellis code with rate 3 bits/4-dimensional symbol having a minimum squared distance d2 m in = 16 was disclosed. In order to achieve a higher transmission rate of 8 bits/4-dimensional symbol, five uncoded bits were added, obtaining an input of eight parallel sequences to the encoder in FIG. 7:
    • {ai 1 }, {ai 2 }, {a3 },..., {ai 8 }. The sequences {ai 2 } {ai 3 } determine the state a i 2 -1 ai 3 -1 ai 3 -2 of the encoder in FIG. 7. An edge joining two states can now be labelled by the sixty-four vectors in the set S(v) U S (-v). This is so because there are sixty-four parallel transitions between states
    • ai 2 -1 ai 3 -1 ai 3 -2 and a2 ai 3 ai 3 -1 corresponding to the sixty-four possible inputs ai 4 ... ai 8. Furthermore, any fixed assignment of code symbol in S(v) U S(-v) to inputs a) ai 4... ai 8 is permitted.
  • The properties (M1) and (M2) guarantee that the squared distance of any error event is at least 16. Consider any error event in the eight state trellis of length 1. If the squared distance for the low-rate code is
    Figure imgb0028
    then the squared distance for the high rate code is at least
    Figure imgb0029
    The property (M2) implies that the minimum squared distance of the high-rate code is at least 16. The average signal power P of the 512 point signal constellation is given by the expression:
    Figure imgb0030
    Figure imgb0031
  • Referring to FIG. 8, there is shown a signal constellation comprising sixty-four signal points which is used for standard uncoded transmission at the rate of 6 bits/2-dimensional symbol. To transmit a 4- dimensional symbol at a rate of 12 bits/symbol, a constellation comprising two such copies are needed. The number of possible signals will be 4,096 ( 64 x 64 = 4096 ). The average signal power
    Figure imgb0032
    Thus,
    Figure imgb0033
  • For coded transmission using three bits from prior blocks, 8,192 ( 213 = 8192 ) signal points are needed. As in the 8 bits/4-dimensional symbol, the signal constellation is partitioned into sixteen sets S(w) according to congruence of the entries modulo 4. Each set S(w) will contain, however, 512 signal points, or code words. Representative signal points are listed hereinbelow in Table 3.
    Figure imgb0034
    Figure imgb0035
    Figure imgb0036
  • In order to obtain a transmission rate of 12 bits/4-dimensional symbol it is necessary to add nine uncoded bits to the four derived bits from FIG. 5, to obtain a total of 13. There are now 1024 parallel transitions between states ai 2 -1 ai 3 -1 ai 3 -2 and
    • a2 a3 a3 -1 in the eight state trellis.
  • If the edge corresponding to this transition was originally labelled ± w, it is now labelled with the 1024 vectors in S(w) U S(-w). The metric properties (M1) and (M2) guarantee that the squared minimum distance of the high-rate code is equal to the squared minimum distance of the low-rate code, which is 16. The average signal power is 108.625, and so the figure of merit is:
    Figure imgb0037
    and the coding gain is:
    Figure imgb0038
  • Summarizing the aforesaid disclosure, in order to achieve coded transmission at a rate of k bits per four dimensional signal, (k-3) uncoded bits are added to the low rate trellis code, that is, 3 bits per four dimensional symbol, as disclosed hereinabove, with reference to FIG. 3. There are 2(k-2) parallel transitions between
    • states ai 2 -1 ai 3 -1 ai 3 -2 and
    • ai 2 a3 ai 3 -1 in the eight state trellis.

    Relating this to FIG. 3, there are two parallel transitions between the two aforesaid states because 2(3-2) is 2.
  • Coded transmission requires 2(k+1) signal points. The points of the lattice (2Z + 1)4, where (2Z + 1) represents the set of odd numbers, lie in shells around the origin consisting of sixteen vectors of energy four, sixty-four vectors of energy twelve, ... , shown summarized in Table 3. The 2k+1 signal points are obtained by taking all points of energy four, twelve, twenty, ... and just enough points of a final shell to bring the total number up to 2k+1. The signal constellation is partitioned into sixteen sets S(w) according to congruence of the entries modulo four. Each set contains 2k-3 signal Points. Thus, when k = 8, each set has thirty-two signal points ( 28-3 = 32 ) as is shown in FIG. 9. Edges in the eight state trellis originally labelled + w are now labelled with the 2k-2 vectors in S(w) U S(-w). The metric properties (M1) and (M2) guarantee that the minimum squared distance of this trellis code is sixteen.
  • It can be shown that as k increases, that is, in the limiting case, the limiting coding gain is 10 log10 π = 4.914 db. That is, the maximum coding gain is 4.914 db. But the coding gain for twelve bits per four dimensional symbol is 4.904 db and the coding gain for eight bits per four dimensional symbol is 4.717 db. Thus, the scheme disclosed by the present invention is an efficient method of coding.

Claims (6)

1. Apparatus for coding k bits of information, k > 4, into a four-dimensional code-word comprising:
serial to parallel means (70) for converting k serial binary bits into k parallel bits, said parallel bits being separated into first and second groups of signals, said first group of signals comprising k-3 bits and said second group of signals comprising 3 bits;
converter means (72) for converting the binary 1 's to -1 's and binary 0's to 1 's of said first group of signals for addressing any one of a plurality of four-dimensional code words, said code words being stored in a memory device (74), said code words consisting of four odd numbers;
a convolutional encoder (50), which comprises memory means for storing three bits,for expanding the number of bits in said second group of signals by one;
converting means (80) for converting the expanded bits from binary 1's to -1's and binary 0's to 1's; and
multiplying means (82, 84, 86, 88) for multiplying the code words from said read only memory by said expanded and converted second group of signals, which determine the sign of the 4 numbers of the four-dimensional code word, to derive an encoded four-dimensional code word for each block of k bits of information.
2. Apparatus as claimed in claim 1 wherein k = 8, said read only memory comprises a set of thirty-two four-dimensional code words, and
said encoded four-dimensional code-word is any one signal of a signal constellation comprising five hundred and twelve four-dimensional code words.
3. Apparatus as claimed in claim 1 wherein k = 12,
said read only memory comprises a set of five hundred and twelve four-dimensional code words, and
said encoded four-dimensional code-word is any one signal of a signal constellation comprising eight thousand, one hundred and ninety-two four-dimensional code words.
4. A method of coding k bits of information, k > 4, into a four-dimensional code-word comprising:
converting k serial binary bits into k parallel bits, said parallel bits being separated into first and second groups of signals, said first group of signals comprising k-3 bits and said second group of signals comprising 3 bits;
converting the binary 1's to -1's and binary 0's to 1's of said first group of signals for addressing any one of a plurality of four-dimensional code words, said code words being stored in a memory device, said code words consisting of four odd numbers;
expanding the number of bits in said second group of signals by one by means of an eight-state convolutional code;
converting the expanded bits from binary 1 's to -1 's and binary 0's to 1 's; and
multiplying the code words from said read only memory by said expanded and converted second group of signals, which determine the sign of the 4 numbers of the four-dimensional code word, to derive an encoded four-dimensional code word for each block of k bits of information.
5. A method as claimed in claim 4 wherein k = 8, said read only memory comprises a set of thirty-two four-dimensional code words, and
said encoded four-dimensional code-word is any one signal of a signal constellation comprising five hundred and twelve four-dimensional code words.
6. A method as claimed in claim 4 wherein k = 12,
said read only memory comprises a set of five hundred and twelve four-dimensional code words, and
said encoded four-dimensional code-word is any one signal of a signal constellation comprising eight thousand, one hundred and ninety-two four-dimensional code words.
EP85304296A 1984-06-25 1985-06-17 Multi-dimensional coding for error reduction Expired EP0166560B1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US624274 1984-06-25
US06/624,274 US4581601A (en) 1984-06-25 1984-06-25 Multi-dimensional coding for error reduction

Publications (3)

Publication Number Publication Date
EP0166560A2 EP0166560A2 (en) 1986-01-02
EP0166560A3 EP0166560A3 (en) 1986-12-30
EP0166560B1 true EP0166560B1 (en) 1991-04-03

Family

ID=24501333

Family Applications (1)

Application Number Title Priority Date Filing Date
EP85304296A Expired EP0166560B1 (en) 1984-06-25 1985-06-17 Multi-dimensional coding for error reduction

Country Status (5)

Country Link
US (1) US4581601A (en)
EP (1) EP0166560B1 (en)
JP (1) JP2677348B2 (en)
CA (1) CA1289667C (en)
DE (1) DE3582369D1 (en)

Families Citing this family (27)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4713817A (en) * 1985-04-25 1987-12-15 Codex Corporation Multidimensional, convolutionally coded communication systems
US4713829A (en) * 1985-06-19 1987-12-15 Codex Corporation Coded modulation system with a simplified decoder capable of reducing the effects of channel distortion
US4831635A (en) * 1986-10-02 1989-05-16 American Telephone And Telegraph Company Trellis codes with spectral nulls
JP2521925B2 (en) * 1986-10-14 1996-08-07 日本電気株式会社 Convolutional encoder
US4761784A (en) * 1987-01-15 1988-08-02 Racal Data Communications Inc. Modem and method using multidimensional coded modulation
US4748626A (en) * 1987-01-28 1988-05-31 Racal Data Communications Inc. Viterbi decoder with reduced number of data move operations
US4788694A (en) * 1987-02-20 1988-11-29 American Telephone And Telegraph Company, At&T Bell Laboratories Trellis coding with substrates
US5040191A (en) * 1987-02-24 1991-08-13 Codex Corporation Partial response channel signaling systems
KR910009674B1 (en) * 1987-03-20 1991-11-25 후지쓰 가부시끼가이샤 Digital demodulator apparatus
US4939555A (en) * 1987-05-13 1990-07-03 At&T Bell Laboratories Trellis coding arrangement
US4807230A (en) * 1987-05-29 1989-02-21 Racal Data Communications Inc. Frame synchronization
US4993046A (en) * 1988-06-24 1991-02-12 Nippon Telegraph And Telephone Corporation Coded modulation communication system
FR2634609B1 (en) * 1988-07-22 1990-10-05 Trt Telecom Radio Electr MODULATION DEVICE FOR MODULATING A PHASE AND AMPLITUDE WAVE
US5014276A (en) * 1989-02-06 1991-05-07 Scientific Atlanta, Inc. Convolutional encoder and sequential decoder with parallel architecture and block coding properties
US5150381A (en) * 1989-02-16 1992-09-22 Codex Corporation Trellis shaping for modulation systems
US5113412A (en) * 1990-06-08 1992-05-12 General Datacomm, Inc. Method and apparatus for mapping an eight dimensional constellation of a convolutionally coded communication system
US5048056A (en) * 1990-06-08 1991-09-10 General Datacomm, Inc. Method and apparatus for mapping an eight dimensional constellation of a convolutionally coded communication system
US5351249A (en) * 1991-07-19 1994-09-27 Interdigital Technology Corporation Trellis coded FM digital communications system and method
US5491705A (en) * 1992-06-18 1996-02-13 The United States Of America As Represented By The Secretary Of The Air Force De bruijn graph based VLSI viterbi decoder
KR100195177B1 (en) * 1992-12-31 1999-06-15 윤종용 Trellis coded modulation system
US5646950A (en) * 1994-11-18 1997-07-08 Seagate Technology, Inc. Matched spectral null codes for partial response channels
AUPN455695A0 (en) * 1995-08-01 1995-08-24 Canon Kabushiki Kaisha Qam spread spectrum demodulation system
US5809080A (en) * 1995-10-10 1998-09-15 Mitel Semiconductor Americas Inc. System and method for coding partial response channels with noise predictive Viterbi detectors
US6131180A (en) * 1997-11-03 2000-10-10 Ericsson, Inc. Trellis coded modulation system
US7545890B1 (en) * 1999-01-29 2009-06-09 Texas Instruments Incorporated Method for upstream CATV coded modulation
US8621321B2 (en) * 2010-07-01 2013-12-31 Densbits Technologies Ltd. System and method for multi-dimensional encoding and decoding
US20130142206A1 (en) * 2011-12-06 2013-06-06 Broadcom Corporation Higher dimensional constellations and interleaving for 10gbase-t

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US3909721A (en) * 1972-01-31 1975-09-30 Signatron Signal processing system
CH609510A5 (en) * 1976-06-18 1979-02-28 Ibm
US4084137A (en) * 1976-08-24 1978-04-11 Communications Satellite Corporation Multidimensional code communication systems
US4247944A (en) * 1978-11-15 1981-01-27 Ricoh Co., Ltd. V.29 Constellation detection method and apparatus
US4346473A (en) * 1980-02-26 1982-08-24 Harris Corporation Error correction coding method and apparatus for multilevel signaling
GB2088676B (en) * 1980-11-14 1985-09-04 Plessey Co Ltd Transmission systems
DE3066889D1 (en) * 1980-12-23 1984-04-12 Ibm Method of transmitting binary data sequences and arrangement for enabling the rapid determination of the end of a transmitted binary data sequence
US4457004A (en) * 1982-02-08 1984-06-26 Bell Telephone Laboratories, Incorporated Multidimensional channel coding
US4601044A (en) * 1983-11-04 1986-07-15 Racal Data Communications Inc. Carrier-phase adjustment using absolute phase detector

Also Published As

Publication number Publication date
JP2677348B2 (en) 1997-11-17
US4581601A (en) 1986-04-08
CA1289667C (en) 1991-09-24
EP0166560A2 (en) 1986-01-02
EP0166560A3 (en) 1986-12-30
DE3582369D1 (en) 1991-05-08
JPS6113821A (en) 1986-01-22

Similar Documents

Publication Publication Date Title
EP0166560B1 (en) Multi-dimensional coding for error reduction
US5029185A (en) Coded modulation for mobile radio
KR100446878B1 (en) Method and apparatus for generating dc-free sequences
US5243627A (en) Signal point interleaving technique
JP3115734B2 (en) Data encoding method, data transmission signal processing method, and apparatus therefor
JP3269858B2 (en) Transmission equipment
EP0543070A1 (en) Coding system and method using quaternary codes
EP0707402A2 (en) Trellis coded modulation employing lower dimensionality convolutional encoder
EP0333324A2 (en) Matched spectral null trellis codes for partial response channels
US4457004A (en) Multidimensional channel coding
US4939555A (en) Trellis coding arrangement
JPH028503B2 (en)
US6138265A (en) Decoding trellis coded modulated data with a conventional Viterbi decoder
US4896353A (en) Apparatus for fast decoding of a non-linear code
Pieper et al. Design of efficient coding and modulation for a Rayleigh fading channel
US6324224B1 (en) Apparatus and method for receiving data with bit insertion
EP0991219A2 (en) Concatenated error control method and system for uplink satellite transmission
US6327316B1 (en) Data receiver using approximated bit metrics
US4831635A (en) Trellis codes with spectral nulls
US5982818A (en) Method for implementing trellis codes for ISI channels
US6745365B2 (en) Coder with error correction, decoder with error correction and data transmission apparatus using the coder and decoder
USRE33041E (en) Multi-dimensional coding for error reduction
CN117356077A (en) Method and apparatus for transmitting binary data
Lee et al. Multiple symbol trellis coding of CPFSK
Tretter An eight-dimensional 64-state trellis code for transmitting 4 bits per 2-D symbol

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Designated state(s): CH DE FR GB LI NL SE

PUAL Search report despatched

Free format text: ORIGINAL CODE: 0009013

AK Designated contracting states

Kind code of ref document: A3

Designated state(s): CH DE FR GB LI NL SE

17P Request for examination filed

Effective date: 19870601

17Q First examination report despatched

Effective date: 19890628

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): CH DE FR GB LI NL SE

REF Corresponds to:

Ref document number: 3582369

Country of ref document: DE

Date of ref document: 19910508

ET Fr: translation filed
K2C2 Correction of patent specification (partial reprint) published

Effective date: 19910403

PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

26N No opposition filed
EAL Se: european patent in force in sweden

Ref document number: 85304296.8

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: CH

Payment date: 19990323

Year of fee payment: 15

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: LI

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20000630

Ref country code: CH

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20000630

REG Reference to a national code

Ref country code: CH

Ref legal event code: PL

REG Reference to a national code

Ref country code: GB

Ref legal event code: IF02

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: SE

Payment date: 20020416

Year of fee payment: 18

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 20020524

Year of fee payment: 18

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20020527

Year of fee payment: 18

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: NL

Payment date: 20020531

Year of fee payment: 18

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: DE

Payment date: 20020628

Year of fee payment: 18

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: GB

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20030617

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20030618

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: NL

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20040101

Ref country code: DE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20040101

EUG Se: european patent has lapsed
GBPC Gb: european patent ceased through non-payment of renewal fee

Effective date: 20030617

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: FR

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20040227

NLV4 Nl: lapsed or anulled due to non-payment of the annual fee

Effective date: 20040101

REG Reference to a national code

Ref country code: FR

Ref legal event code: ST