The present invention pertains to a method for coding and decoding an information symbol or stream of information symbols to be transmitted across a transmission channel. Furthermore, the invention pertains to devices for encoding a signal to be transmitted and decoding a signal value received.
Transmission channels must generally deal with echoes, multipath propagation, preoscillation and postoscillation. These effects result in inter-symbol interference (ISI) between symbols occurring consecutively in time. In the general case, it is not possible to invert the transfer function of the transmission channel and thereby eliminate the perturbing influence of the transmission channel.
It is known that the perturbing influence of the transmission channel can be reduced by devices at the receiver side, such as equalizers or maximum likelihood sequence estimation.
At the sending side of a transmission system, precoding represents a way of reducing the perturbing influence of ISI caused by the transmission channel. Based on the Tomlinson Method as described by M. Tomlinson in “New Automatic Equalizer Employing Modulo Arithmetic,” Electronics Letters, 25 Mar. 1971, Vol. 7, pp. 138-139, numerous investigations have been conducted on the topic of precoding and various precoding variants have been developed.
Both the Tomlinson Method and all other known preceding variants nevertheless require a certain computation expenditure at the receiver side in the form of operations which are adapted to the precoding at the sending side.
In view of this problem, the invention provides a method and a device for the encoding and decoding of information signals by which the required computational expense can be diminished, especially at the receiving side.
According to the invention, a stable transmission of predistorted symbol streams across transmission channels with strong reflection can be achieved with little computational expense at the receiving side. For this, a channel symbol alphabet is defined, which is more powerful, i.e., it contains more elements, than the alphabet of the information symbols being transferred (information symbol alphabet). Due to the fact that the channel symbol alphabet is more powerful than the information symbol alphabet, the result is possibilities for choosing the form in which an information symbol can be transmitted by means of different channel symbols. Therefore, the encoding or precoding method proposed herein is designated hereafter as multiple-choice preceding (MCP). Said possibility of choice is utilized so that a transmission value is sent with the lowest possible energy at the sending side, while the ISI produced by it has minimal perturbation or is even constructive in effect.
Compared to known precoating methods, the advantage of MCP consists in the fact that no additional computational operations are required at the receiving side. This not only reduces the costs, but also any time delay or sources of error such as quantization errors or parameter inaccuracies. As a kind of side effect, in the case of constant symbol sequences MCP can take on the function of a scrambler (cf. Lochmann: Digitale Nachrichtentechnik, Verlag Technik GmbH, Berlin 1997, 2nd edition, ISBN 3-241-01184-6) and thereby facilitates the bit sequence-independent symbol synchronization at the receiving side with high data rates.
From U.S. Pat. No. 5,570,388 a method of a device is known wherein simple codes are used for wireless transmission of nondata symbols. This publication defines a “spare symbol,” yet unlike the present invention this carries no information, but instead fulfills a delimiter function.
From DE 199 12 825 there is known a method of a receiving arrangement for a radio station to detect a data symbol. A certain agreement with the present invention consists in that distances from constellation points (or constellation regions in the present invention) are determined and taken into account. In contrast to the present invention, however, all calculations take place at the receiving side and not, as in the present invention, at the sending side. The teaching of DE 199 12 825 in no way achieves the goal of having the receiving side be organized as simple as possible.
From DE 198 24 408 there is known a receiver for a digital transmission system, yet as in the case of DE 199 12 825 it specifies a special equalizer at the receiving side, by which the necessary computations are carried out.
From DE 44 40 947 a method is known for digital transmission of messages. This publication makes close reference to the Tomlinson-Harashima Method and describes a further development of same. The publication quite generally goes into the lessening of signal dynamics at the receiving side. An important difference between what is disclosed in DE 44 40 947 and the present invention is that, with the Tomlinson-Harashima Method as well as DE 44 40 947, a modulo-N operation with respect to the signal amplitude is required at the receiver side. As is further pointed out in DE 44 40 947, due to the periodic continuation of the amplitude constellation on a real-valued axis in the Tomlinson-Harashima Method there are not many signal values to represent a signal symbol or many signal values to represent a transmitter symbol according to DE 44 40 947.
In the present invention, on the other hand, one essentially uses a complex plane. In the sample embodiment provided in the present application, the channel symbol alphabet differs from the information symbol alphabet also in the number of possible phase values of its elements. Because of the direct use of the complex plane, the problem of intensified signal dynamics at the receiving side does not occur in the present invention and an infinite predictable set of “sending values” is not required as in the Tomlinson-Harashima Method.
Preferably, the position of an uncertainty region in the complex plane is defined by the channel properties and by the sending values which were sent in the past, and the size and shape of this uncertainty region are defined by the sending values to be sent in future. The position of the uncertainty region is determined by an ISI component EISIpost, which can be exactly calculated in advance by means of the channel properties and the sending values sent in the past. An additional ISI component EISIpre, which is created by future sending values interacting with the channel properties, cannot be exactly computed in advance because of causality reasons. The shape and size of the uncertainty region, however, allow for the possible influence which EISIpre might have in the detection of the signal currently being transmitted. The choice at the sending side of the desired channel symbol which can be chosen at the receiving side is based on its position in relation to the presently calculated uncertainty region.
The channel properties, especially the preoscillation and postoscillation behavior of the transmission channel, can be determined preferably by means of the channel pulse response. The channel pulse response can be found by measurement techniques, for example, and be updated in predetermined intervals of time.
According to a preferred embodiment, one can select the channel symbol which has the smallest distance in the complex plane from all selectable channel symbols and thus has the smallest correction value with regard to the point of the uncertainty region which is most distant from it. This “minimal maximum value” is hereafter termed the “smallest correction value”. This selection criterion ensures a high probability of the correct decision at the receiving side with regard to the channel symbol contained in the reception value, while at the same time minimizing the energy of the sending value.
According to another advantageous embodiment, the sending value “0” (physically nothing is sent) can occur if the presently calculated uncertainty region is situated in an area which leads with high probability to a decision at the receiving side for a channel symbol that can be selected for the transmission of the present information symbol. This means that the ISI produced by past sending values has constructive effect and is sufficient for transmitting the channel symbol selected for the present information symbol.
Preferably, one can delimit the region of the sending value by limiting the complex components of a sent sending value to a maximum value each time. This results in a limiting of the transmission energy.
As the distance used during the decoding, one can preferably calculate a Euclidean distance or a Hamming distance. These quantities furnish a measure for the decision-making distance between different possible channel symbols.
According to another advantageous embodiment, the calculating arrangement provided in the encoding device can comprise a first memory arrangement for storing the sending values already sent, a second memory arrangement for storing of channel coefficients which describe the postoscillation of the transmission channel, a multiplication arrangement for multiplying the sending values already sent with the corresponding channel coefficients, and an addition arrangement for adding up the results of the multiplication. By progressively storing the sending values already sent in the first memory arrangement and updating in time the channel coefficients in the second memory arrangement, a simple adaptation of the encoder to the given transmission situation is possible with low computational expense. The expected reception signal values can then be computed in advance in the calculating arrangement, preferably by means of the addition result, the selected channel symbol, and an expectation value taking into account the preoscillation behavior of the transmission channel. This makes it possible to factor in the preoscillation behavior of the transmission channel. In order to reduce the ISI caused by the preoscillation behavior, a prefilter adapted to the transmission channel can also be provided.
The invention shall now be explained more closely by means of a preferred sample embodiment making reference to the enclosed figures. These show:
The preferred sample embodiment shall be explained hereafter, at first in general form and then on the special example of a BPSK modulation.
where n corresponds to the memory depth of a channel 20 used for the transmission with the characteristic
with h0, hn≠0, and thus the channel order.
The sending value zi(tx) generated in a pre-encoder 10 of a transmitter 100 by the MCP method is sent via the channel 20. From the reception value zi(rx) arriving at the input of a receiver 30 after a time delay, the fundamental channel symbol yi(rx) is determined by means of a decider 31. From this channel symbol yi(rx), a received information symbol vi(rx) is detected or determined by means of an assigner 32, making use of a mapping function f(·), which is a simple single-valued but not reversible mapping. For this detection process, a detection error Derr (z(rx), y(rx), v(tx)) is defined according to the following equation (2), which can be computed in advance at the transmitter side. Derr (·) is dependent on the reception value z(rx) calculated in advance at the decider input, the channel symbol y(rx) detected from this, and the desired information symbol v(tx) which should appear at the receiver output:
The function BordDist (z, y) provides the decision-making distance (see
Thus, the detection error Derr (z(rx), y(rx), v(tx)) is a measure of the uncertainty with which an information symbol v(tx) is correctly detected for a given reception symbol z(rx). The smaller the detection error, the more certain the detection. A negative detection error indicates that the reception symbol z(rx) lies within the certain decision-making region of a channel symbol y(rx) and that this channel symbol is mapped on the correct information symbol.
According to the preferred sample embodiment, at the transmitter side one calculates in advance the region in which the reception value will lie that the receiver will afterwards detect on the basis of the sending value now being determined. This requires at the transmitting side both knowledge of the channel
where δi,j is the Kronecker symbol. Thus, the reception value received after m symbol time steps would correspond to the sent sending value as expected. On the other hand, in a real-world system, the reception value zi(rx) will contain interference components from symbols situated near in time, as well as additive noise, due to the channel properties.
In order to allow for the preoscillation and postoscillation of the channel pulse response, it is assumed that the effective channel pulse response of the channel 20 located between the transmitter 100 and the receiver 30 has the following characteristic:
|h0|,|h1|, . . . |hm−1|<1, hm=1, |hm+1|,|hm+2|, . . . |hn|≦1 (4)
where the coefficients h0, h1, . . . hm−1 describe the preoscillation and the coefficients hm+1, hm+2, . . . hn describe the postoscillation of the channel pulse response. Because of the delay m, the reception value z0(rx) detected at the receiver input at time i=0 is:
The first summand on the left side of equation (5) describes ISI components EISIpost that can be described by sending values which were sent prior to the sending value z−m(tx) in time and are attributable to the postoscillation (post-cursor) of the channel, while the last summand describes the ISI components EISIpre that are caused by preoscillation (pre-cursor) and are dependent on sending values that were sent after the sending value z−m(tx) in time and consequently were not yet known when the sending value z−m(tx) was sent. This can be represented by the following equation (6):
The right side of the equation (6) shows that the reception value can be interpreted as the sum of a transmitted channel symbol and an error value caused by interferences.
In order to allow for the preoscillation of the channel 20, one establishes an upper limit value K for the expectation value E{·} of the sending symbols, so that: E{|z(tx)|}≦K. Thus, E0ISIpre can be estimated from above. With the equation:
with the definition (A B: A implies B) one gets:
|E0ISIpre|≦d|real(E0ISIpre)|≦d, |imag(E0ISIpre)|≦d, (8)
and in the following remarks we shall assume K=1. While the left side of equation (8) represents a circular disk in the complex plane, the right side of equation (8) describes a square which contains this circular disk and which shall be used for the further calculations for reasons of simplicity.
Thus, the reception value z0(rx) detected at time i=0 was not exactly localizable in advance as a point in the complex plane at time i=−m. Therefore, a square region S(rx)(z) is defined by the following equation (9), within which the reception value is expected:
is defined hereafter as the uncertainty region at time i=0. It designates the region in which the ISI occurring at the receiver input at time i=0 must lie with high probability. Consequently, the region S(rx)(E0ISIpost+z−m(tx)) describes the region in which the reception value z0(rx) must lie with high probability. The size of the uncertainty region S(rx)(E0ISIpost) depends on the preoscillation behavior (oscillation build-up behavior) of the channel 20. If one further allows for the general requirement of sending out the lowest possible symbol energy in order to keep low any overmodulation distortions, the calculation of z−m(tx) leads to the following optimization problem:
Find the z−m(tx)=zopt that requires the lowest possible transmission energy, i.e.
zopt=min(|z|2), (10a)
under the accessory conditions that z is contained in the set of possible sending symbols, i.e.
zεZ(tx) (10b)
and that, for all z0(rx)εS0(rx), (E0ISIpost+z) leads to a correct detection of the information symbol at the receiver 30, i.e.
Thus, we have a nonlinear restrictive optimization problem. Without having accomplished an analytical proof of the solvability of this optimization problem, an easily implemented sample embodiment is given below, which solves at least approximately the above-defined optimization problem.
The pre-encoder function provided in the pre-encoder 10 can be realized in the form of a table of values after the channel property is discovered. The table of values can be realized, for example, as a table of values for probable types of channel pulse responses, and a selection can then be made using the measured channel property.
Using a discrete convolution, the channel coefficients hj are multiplied with the corresponding stored sending values zj in corresponding multiplication arrangements and added together in an addition arrangement, in order to obtain in this way a characteristic value for the particular postoscillation of the channel 20, which is supplied to the symbol selector 12 and used to calculate the expected reception values or range of values (i.e., the uncertainty region S) used for the selection of the suitable channel symbol.
The channel symbol y selected by the symbol selector 12 and the uncertainty region S(rx) (EISIpost) calculated in the symbol selector are used by a sending value calculator 15 to calculate the present sending value z−m(tx) as described hereafter.
The blocks shown in
In step S100, the pre- and postoscillation behavior of the channel 20 is first determined, for example, by means of a measured channel pulse response
The sending value zi(tx) to be emitted at time i is determined as follows. In step S101, the uncertainty region produced by the ISI for the reception at the receiver 30 at time i+m is calculated per equation (9a). This can be done, for example, by calculating the corner points of the uncertainty region S(rx)(Ei+mISIpost). After this, in step S1102, the channel symbol which lies closest to the uncertainty region is determined. This can be done, for example, by determining, for each channel symbol yj k, j=1, . . . p, that is possible for vi(tx), the difference value between channel symbol and corner point of the uncertainty region S whose value is a maximum, by the following equations (11a) and (11b). For an uncertainty region with the four corner points (c1,c2,c3,c4) we have:
(where the arg(max(f1)) operation can furnish the argument 1 for which f1 is a maximum)
z(max)(j)=yj−cl
Each time the channel symbol with the smallest correction value z(diff) is chosen as the desired channel symbol y(tx) that is to be generated at the receiver input with the sought sending value, and the smallest correction value z(diff) is placed in buffer memory for further calculation steps. Thus:
A decision is now made as to the position of the expected ISI component Ei+mISIpost.
If the expected ISI component Ei+mISIpost in case A is located inside the “inner region” covered by the channel symbols, such as the square constructed by the four channel symbols of a conventional QPSK modulation (see
(with the definition A−>B: if A, then B)
If, on the other hand, in a case B, the ISI component Ei+mISIpost is already in the decision-making region of the desired channel symbol, the sending value “0” will be sent (S104), since no correction is required. Thus, in case B (with the definition sign(x):Signum(x)):
In all other situations (Case C), one transmits (S105), for example, the component of z(diff) that pertains to the smaller component (real( ),imag( )) of Ei+mISIpost. This is possible in this case, since only one component of z(diff) is already enough to accomplish a secure detection region for the reception value based on the uncertainty region S(rx)(EISIpost) calculated in advance. Thus, in case C:
In step S106, a limiting of the region can then occur by limiting the complex components of the sent sending value according to the following equations (16a) and (16b), in order to limit the maximum transmission energy:
|real(zi(tx))|>rmax−>real(zi(tx))=sign(real(zi(tx)))·rmax (16a)
|imag(zi(tx))|>rmax−>imag(zi(tx))=sign(imag(zi(tx)))·rmax (16b)
The region can also be limited by limiting the amplitude of the complex sent signal value to a maximum value.
Finally, in step S107 the defining moment of time for selection of the next sending symbol is incremented, i.e., i=i+1.
In practice, one can often count the set Z of possible sending values (discrete, finite number). In this case, the range of values of many of the quantities calculated in the above algorithm, such as Ei+mISIpost, z(max)(k), can also be counted. Therefore, even prior to transmission, the possible values of many quantities can be calculated in advance and placed in tables of values. This will minimize the computational time outlay during the transmission.
The mode of functioning of the decoding method carried out in the receiver 30 shall now be explained by means of the flow chart of
In step S200, a reception value z is received and taken to the decider 31. The decider 31 compares the reception value with predetermined decision-making regions for the possible channel symbols y according to the channel symbols available Y, in order to determine the received symbol (S201). This occurs according to equation (2). In the case of a QPSK modulation, the decision-making regions at the reception side can be the quadrants in the complex plane, for example.
In step S202 of
As a closer example, we shall now consider the case when the information symbol alphabet comprises two characters, which holds for BPSK, for example:
V=[v1=−1, v2=+1]. (17)
Let the set of possible sending symbols be given by a square with length of side 2rmax at the origin of the complex plane, according to the following definition:
Z(tx)={z|−rmax<real(z)<rmax^−rmax<imag(z)<rmax} (18)
Accordingly, a QPSK modulation is defined as the channel symbol alphabet:
Y=[y1=+1+j, y2=−1+j, y3=−1−j, y4=+1−j]. (19)
Thus, for the mapping function f(·), which maps the channel symbols in the assigner 32 onto the information symbols, we have:
ƒ(y1=+1+j)=+1
ƒ(y2=−1+j)=−1
ƒ(y3=−1−j)=+1
ƒ(y4=+1−j)=−1 (20)
There exist thus p=2 channel symbols which can be selected for the transmission of a given information symbol.
It is assumed that the channel does not have intense preoscillation and consequently:
hi<<hm for i<m. (21)
In practice, such a behavior can be assured by using a linear prefilter, adapted to the channel.
If, on the contrary, one uses the above-described MCP encoding method, one gets a constellation per
A simple detector, which detects the underlying information symbol v by means of the quadrant in which a reception symbol lies, would produce an error-free stream of reception symbols at the receiver output in this case.
We shall now discuss the scrambling function as an incidental benefit of the MCP encoding method, using the representation in
The method described in the present application can also be summarized by saying that one makes a selection from p possible representations (channel symbols) for an information symbol which is to be transmitted from a transmitter to a receiver and determines the sending value which is required for the selected channel symbol to appear in the receiver's input. Minimization of the energy of the sending value serves as the criterion of choice. Therefore, the invention can also be described as a symbolwise multiple-choice-precoding (MCP). One possibility of expanding the symbolwise MCP is a forward-looking MCP, as depicted in a flow chart per
If one inserts the real and imaginary parts of a sequence of sending values for x, the unit matrix for H, the null vector for f, the convolution matrix for A, which can be formed from the known channel pulse response, and the real and imaginary parts of a representation sequence for b, one can now compute this representation sequence with the general methods of optimization theory as the optimal sequence of sending values for energy minimization. This involves a certain amount of numerical expense. Yet the advantage of this technique is that, with the present invention (MCP), it is also applicable to channels with any given preoscillation, without requiring the use of a FIR filter.
As shown, the described algorithm implicitly contains a scrambling function when the channels are sufficiently distortion-rich. In order to also furnish a scrambling function when the channels are distortion-free or distortion-poor, the desired channel symbol y(tx) can be randomly selected, for example. In this way, a good dynamics is ensured in the reception symbol sequence for each information symbol sequence and, thus, code transparency for the method.
The invented encoding method (MCP) is based on the basic notion of a channel symbol alphabet which is more powerful than the information symbol alphabet, i.e., the channel symbol alphabet contains at least one more element than the information symbol alphabet. By using an enhanced linearity and dynamic region at the sending side, the intersymbol interference caused by the channel is drastically reduced with minimal expense at the receiver side. Since it is calculated in advance at the transmitter side which values will come under the channel influence at the receiver side, knowledge of the channel pulse response at the transmitter side is necessary. In view of the fact that any filtering and synchronization operations in the receiver also have influence on the resulting channel pulse response, these operations can and should be easily predictable, or at least predictable at the transmitter side. The constellations obtained at the receiver input by simulation give us an idea as to the performance of the MCP method.
In practice, situations exist in which, at a sending time j, besides the present information symbol there are also already known the following L information symbols vj,vj+1, . . . ,vj+L being transmitted. Therefore, one way of expanding the sample embodiment is to consider these future L information symbols when determining the current sending value zj(tx). For this, one calculates in advance all possible channel symbol sequences:
ykj,ykj+1, . . . ykj+L
which are considered for representing the information symbol sequence vj,vj+1, . . . ,vj+L, for example. The current sending value zj(tx) is then determined such that a minimum anticipated required sending energy results for the next L symbols, i.e.,
and all zi are contained in the set of possible sending symbols, i.e.,
ziεZ(tx) (i=j,j+1, . . . ,j+L)
and the detection at the receiver side is possible without error for presumably all zi, i.e.,
Dierr<0 (i=j,j+1, . . . ,j+L)
Since computing power is freed up at the receiver side for equalization when MCP is used, it is possible to either economize this computing power entirely, or to use it to further improve the transmission. For example, it is possible to provide an adaptive equalizer at the receiver side in addition to MCP, which will track and compensate for the deviation between the measured channel pulse response and the actual channel pulse response necessarily occurring in practice. The advantage over a solution without MCP consists in that the adaptive equalizer with MCP only has to correct the distortions contained in the reception value by reason of the deviation between the measured channel pulse response and the actual or effective channel pulse response. This can be done with lower numerical resolution and, thus, lower costs than a solution without MCP.
The MCP method can be used advantageously in applications, for example, where time-invariant channels with strong reflections are disrupting the communication between a base station and many subscriber stations as the main source of interference, such as WLL systems. Of course, the MCP method can also be used advantageously in higher-stage PSK and in DPSK modulation methods or also in other suitable types of modulation.
Furthermore, it is also apparent that bit sequence-independent synchronization is facilitated and thus can be made more cheap with MCP for all data rates.
Number | Date | Country | Kind |
---|---|---|---|
100 44 227.7 | Sep 2000 | DE | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP01/10140 | 9/4/2001 | WO | 00 | 7/3/2003 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO02/21783 | 3/14/2002 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5159610 | Eyuboglu et al. | Oct 1992 | A |
5455839 | Eyuboglu | Oct 1995 | A |
5570388 | Halpern | Oct 1996 | A |
5696769 | Choi et al. | Dec 1997 | A |
Number | Date | Country |
---|---|---|
44 40 947 | Apr 1996 | DE |
199 12 825 | Aug 2000 | DE |
0 555 013 | Aug 1993 | EP |
Number | Date | Country | |
---|---|---|---|
20040008797 A1 | Jan 2004 | US |