The present invention relates to code division multiple access (CDMA) communication systems and, more particularly, to direct sequence CDMA (DS-CDMA) systems having reduced peak-to-average power ratios (PAPRs).
CDMA techniques transmit multiple information signals on the same channel, and differentiate each user sub-channel by encoding it with a unique spreading code. Originally, CDMA networks were designed to carry only voice traffic and exhibited limited data rate variability. CDMA networks, however, are evolving to encompass a variety of applications, each requiring potentially different data rates or quality of service needs. A CDMA system that employs four spreading codes is said to have a “spreading factor” of four and can transmit four distinct streams of data.
The output of a given CDMA transmitter is generally the sum, s, of each data stream multiplied by the corresponding spreading code. In a system having a spreading factor of four, there are 16 possible output vectors, s. It can be shown that the peak-to-average power ratio of such a CDMA system is the maximum value over each possible output vector, s, of the peak energy divided by the average energy. If the peak-to-average power ratio of a CDMA system is greater than one then it is obvious that power of different signals vary. Thus, when the output vector, s, is amplified prior to transmission by a non-linear amplifier, which are commonly found in communications devices, the transmitted signal will be amplified differently for each possible output vector, s, creating non-linear distortion.
A need therefore exists for a CDMA system that provides a reduced peak to average power ratio.
Generally, a method and apparatus are provided for generating a code book for use in a CDMA system. The code book comprises of a plurality of vectors that are used to encode user data. According to one aspect of the invention, the amplitude and polarity for each vector in the code book are selected to provide a reduced peak-to-average power ratio. The amplitude values can be selected to provide a reduced peak-to-average power ratio while maintaining a desired average energy per chip. The desired energy per chip can be based on the energy per chip of a CDMA system having a lower order spreading factor.
In one exemplary implementation, a CDMA system has a spreading factor of eight for communicating eight distinct data streams. One or more of the data streams can be reserved to maintain a desired data rate, such as a data rate of a CDMA system with a spreading factor of four. The exemplary code book employs vectors having amplitude values that provide a significant reduction in the peak-to-average power ratio, relative to a frequently deployed conventional CDMA system having a spreading factor of four. In a further variation, performance can be further improved by employing a first code book under a first signal-to-noise ratio condition and a second code book under a second signal-to-noise ratio condition.
From the system point of view, a CDMA transmitter incorporating features of the present invention comprises a plurality of multipliers that multiply an encoded data stream by a corresponding spreading code. The encoded data stream is based on a code book comprised of a plurality of vectors, each of the vectors having non-uniform amplitude values selected to provide a reduced peak-to-average power ratio, in accordance with the present invention.
A more complete understanding of the present invention, as well as further features and advantages of the present invention, will be obtained by reference to the following detailed description and drawings.
The conventional DS-CDMA system 100 shown in
The vectors c0, c1, c2, c3 are spreading sequences assigned to corresponding information streams.
The spreading sequences c0, c1, c2, c3 are defined as follows:
It can be seen that these sequences form rows of the well-known Hadamard matrix H4 of dimension four (see, e.g., F. J. MacWilliams and N. J. A. Sloane, The Theory of Error-Correcting Codes, North-Holland (1977)), as follows:
and therefore they are orthogonal. In other words
where the multiplication · is the inner product of two vectors defined by the following rule:
(x0,x1, . . . , xn-1)·(y1,y2, . . . , yn-1)=x0y0+x1y1+ . . . xn-1yn-1.
For example,
c1·c2=(1,−1,1,−1)·(1,1,−1,−1)=1−1−1+1=0, but
c1·c1=(1,−1,1,−1)·(1,−1,1,−1)=1+1+1+1=4.
The output vector s=(s0,s1,s2,s3), which is later modulated and then transmitted into the channel, is computed as follows:
s=a·H4=a0c0+a1c1+a2c2+a3c3.
The multiplication operation aici occupies four chips of time. Therefore, in any DS-CDMA system, such as the DS-CDMA system 100 of
Thus, the DS-CDMA system 100 is a system in which the variables a1,a2,a3 take new values every four chips, and the variable a0 takes a new value only every m chips, where m is an integer divisible by 8. It is assumed that the 0th stream plays a special role in the system 100. For example, the 0th stream of a mobile telephone can be used for transmitting voice, while other streams can be used for transmitting data. The voice changes significantly slower compared to data and therefore a0 has to take a new value only every i consecutive chips. Another common and important case is when the 0th stream is used for transmitting a pilot signal. The pilot signal usually remains constant for a long time interval, typically 256 chips, that allows the decoder to accurately estimate the channel fading coefficient.
The rate of a DS-CDMA system 100 is defined as the average number of information bits transmitted per chip. It is easy to see that the DS-CDMA system 100 has the following rate:
Decoding
During transmission through an exemplary channel, the vector s is corrupted by additive noise and the vector x=s+z is received, where z is a vector of noise. To recover a value of ai, a despreading procedure is used, which consists of multiplying the received vector x by the vector ci:
hi=x·ci=(s+z)·ci=(a0c0+a1c1+a2c2+a3c3)·ci+zci. (3)
Taking into account the orthogonality property of equation (1), the following is obtained:
hi=4ai+z·ci.
Finally, the sign of hi is computed and the original bit is reconstructed as âi=sign(hi)a. If the channel noise is not very strong, in other words, if entries of the vector z are small numbers, then with a large probability the quantity |z·ci| will be smaller than |4ai|. Therefore, hi will have the same sign as ai, and hence âi will be equal to ai.
For example, without loss of generality it can be assumed that a=1. Let a=(1, −1, 1, 1) and z=(2.1, −1.8, −1.85, −1.75). Then, s=(2, 2, −2, 2) and h=(2.1, −1.8, −1.85, −1.75). Computing, for instance, h1 according to equation (3), h1 equal to −3.3 and â1=a1 are obtained.
Since the variable a0 changes its value only every m chips and since it is spread with the help of the sequence c0=(1,1,1,1), the value of a0 is reconstructed using a different rule. x(i), i=1, . . . , m/4 denotes vectors received from the channel after transmitting m chips. z(i), i=1, . . . , m/4 denotes the corresponding noisy vectors. To determine the value a0, compute:
and reconstruct â0=sign(h0)a. It can be shown that the probability of decoding error, defined below, is significantly lower for a0 compared to other values of ai.
The bit error probability of a DS-CDMA system, such as the DS-CDMA system 100, is defined as follows:
Pr(âi≠ai)=Pr(sign(âi)≠sign(ai)).
PAPR of the DS-CDMA System 100
The energy of a vector of signals x=(x0, x1 . . . , xn-1) is defined as x02+x12+ . . . +xn-12.
Hence, the average energy per chip of an output vector s equals:
The average energy per chip for the system is defined as the value E(s) averaged over all 16 possible vectors s corresponding to vectors from code book A, shown in
The peak energy of s is defined as
The peak to average power ratio of the DS-CDMA system 100 equals:
Thus, the peak to average power ratio will vary. For non-linear amplifiers, which are commonly found in communications devices, such as mobile telephones, different components of the transmitted signal will be amplified differently, creating non-linear distortion. A need therefore exists for a DS-CDMA system that provides a reduced peak to average power ratio.
Let Hn be an n dimensional Hadamard matrix and y=(y0, . . . , yn-1) be a real vector and v=yHn. The Parseval rule (see, e.g., F. J. MacWilliams and N. J. A. Sloane, The Theory of Error-Correcting Codes, Chapter 14.3, Corollary 3) relates the energy of the vector y, which equals
E(y)=y02+ . . . +yn-12,
to the energy of the vector v, E(v)=v02+ . . . +vn-12, by the following equality:
E(v)=nE(y) (7)
If a vector a=(a0,a1,a2,a3) is transmitted, then according to the Parseval rule (equation (7)), the corresponding output vector s will have the following average energy per chip:
Thus, according to equation (4):
EA=4a2. (9)
The PAPR of the DS-CDMA system 100 is now estimated. It can be shown that half of the output vectors s=(s0, s1, s2, s3) have the property that three variables of s0, s1, s2, s3 are zeros and one variable has the absolute value |4a2| For instance, if a=(a, a, −a, −a), then the corresponding output vector has the form s=(0, 0, 4a, 0). The second half of the output vectors have the property that all s0, s1, s2, s3 variables have the same absolute value |2a|. For instance, if a=(a, −a, a, a), then s=(2a, 2a, −2a, 2a). Therefore, according to equations (6), (5), and (9), the peak to average power ratio of the DS-CDMA system 100 can be expressed as follows:
Improved DS-CDMA System
Vectors b=(b0, b1, b2, b3, b4, b5, b6, b7) are taken from the code book, defined below in conjunction with
The spreading sequences w0, w1, . . . , w7 can be expressed as follows:
w
0=(1, 1, 1, 1, 1, 1, 1, 1,);
w
1=(1, −1, 1, −1, 1, −1, 1, −1,);
w
2=(1, 1, −1, −1, 1, 1, −1, −1,);
w
3=(1, −1, −1, 1, 1, −1, −1, 1,);
w
4=(1, 1, 1, 1, −1, −1, −1, −1,);
w
5=(1, −1, 1, −1, −1, 1, −1, 1,);
w
6=(1, 1, −1, −1, −1, −1, 1, 1,);
w
7=(1, −1, −1, 1, −1, 1, 1, −1,).
The sequences w0, w1, . . . , w7 form rows of the Hadamard matrix H8 of dimension eight (8), and therefore they are orthogonal. The variables b1, . . . , b6 take new values every eight chips and the variable b0 takes a new value every m chips. It is noted that during a time interval of 8 chips, the conventional DS-CDMA system 100 can transmit 6 bits (over two cycles). Thus, in order to transmit 6 bits with the DS-CDMA system 300 in the same time interval of 8 chips, only six user streams are needed. According to one aspect of the invention, the seventh user stream can be used to maintain performance (e.g., to improve the PAPR). Thus, during m chips the DS-CDMA system 300 will transmit
bits of information and therefore the rate of the DS-CDMA system 300 equals the rate of the conventional DS-CDMA system 100:
To be able to transmit seven streams of information, a code book of size 27 is needed. Instead of defining a code book for the DS-CDMA system 300 explicitly, the code book is defined using an algorithm. The matrices Gpc and Grm are defined as follows:
The matrices Gpc and Grm are generator matrices of the single parity check code and the first order Reed-Muller code of length 8 (see, e.g. F. J. MacWilliams and N. J. Sloane, The Theory of Error-Correcting Codes, North-Holland (1977)). They define properties of a code book B.
Let a be the signal amplitude used in the conventional DS-CDMA system 1100 and c, e and d be signal amplitudes for the DS-CDMA system 300 of the present invention. Let a binary vector u=(u0, u1, . . . , u6) take all 27=128 possible values from (0, 0, . . . , 0) to (1, 1, . . . , 1). For each vector u, the corresponding vector b is defined according to the following code book generation process 400, shown in
1. Compute v=uGpc
2. Compute h=Grmv⊥ (here ⊥ indicates the vector transposition);
3. If h⊥=(0,0,0,0) then assign t=2, else assign t=1;
4. Let vi=1−2vi, i=0, . . . , 7;
5. Form the vector b as follows. If t=1 then assign b0=av0 and bi=cvi, i=1, . . . , 7, else assign b0=av0, bi=evi, i=1, . . . , 6, and b7=−dv7.
Vectors b form the code book B.
For example, let u=(0, 1, 1, 0, 0, 0, 0). Then, v=(0,1,1,0,0,1,1,0) and further h⊥=(0,0,0,0). Therefore, t=2 and b=(a,−e,−e,e,e−e,−e,d).
It can be shown that any vectors u whose entries u4,u5,u6 are all zeros will lead to t=2. In a further example, let u=(0, 1, 1, 0, 0, 0, 1). Then, v=(0, 1, 1, 0, 0, 1, 0, 1) and further h⊥=(0, 1, 0, 0). Therefore, t=1 and b=(a, −c, −c, c, c, −c, c, −c).
It can be shown that any vectors u in which at least one of entries u4,u5,u6 is not zero will lead to t=1.
PAPR of the DS-CDMA System 300
Vectors b that correspond to the case t=1 are referred to as vectors of the first type and vectors b that correspond to the case t=2 vectors of the second type. It can be shown that the number of vectors of the first type is 7·16=112 and the number of vectors of the second type is 16.
The power of a vector of the first type is a2+7c2. The power of a vector of the second type is a+6e2+d2. The total number of vectors is 27=128. Hence, the average energy of a vector from the code book equals
Using the Parseval rule of equation (7), the average energy per chip is expressed as follows:
In order to maintain the average energy per chip in the DS-CDMA system 300 the same as in the conventional DS-CDMA system 100, the amplitudes e, c, and d must be selected so that EB=EA, where EA is defined in equation (8).
Consider the PAPR of the DS-CDMA system 300 of the present invention. It can be shown that for any vector b of the first type, the corresponding output vector s=bH8 will have one and the same set of absolute values of entries:
{|a+3c|,|a−c|,|a−5c|}.
It is noted that the vectors u that produce vectors b of the first type belong to cosets of the first order Reed-Muller code with the coset leader of weight two. The same is true for vectors b of the second type. In this case, the set of absolute values of entries of the output vector s=bH is expressed as follows:
{|a+6e−d|,|a+d|,|a−2e−d|}.
Thus, the PAPR of the DS-CDMA system 300 is expressed as follows:
To obtain a system with a small PAPR, the amplitudes b, c, and e must be selected to provide EB=EA and minimize expression (11).
In one exemplary solution of this optimization problem, the following amplitudes were obtained:
c=0.6125123893·a, e=0.611·a, d=1.837572876·a.
It can be shown that under this choice, EB=EA and PAPR=2.013.
Variations of the DS-CDMA System 300
In addition to a small PAPR, a small bit error probability is also desired. A decoding algorithm will be described in the next section. It is noted that for minimizing the bit error probability, different approaches are used for channels with low and with high signal to noise ratios (SNR). In a channel with a high signal to noise ratio, a code book with a large minimum distance will have smaller bit error probability. The minimum distance of code book B is defined as follows:
d(B)=min{dist(x, y)=(x0−y0)2+(x1−y1)2+ . . . +(x7−y1)2: x, y∈B}.
It is can be shown that vectors of the form
will have the minimum pairwise distance, say d1, among all pairs of vectors of the first type. Similarly, the vectors of the following form:
will have the minimum pairwise distance, say d2, among all pairs of vectors of the second type.
Finally, the vectors of the folllowing form:
will have the minimum pairwise distance, say d3, among all pairs of vectors one of which is a vector of the first type and another is the vector of the second type. As previously indicated, for achieving small bit error probability in a channel with large SNR, the minimum distance of the code book must be maximized. This can be done by changing values for the constant amplitudes c, d, and e, which increases the PAPR of the system.
Assume that a PAPR equal to 2.2 is desired. It can be shown that the minimum of distances d2 and d3 will define the minimum distance of the code book, while the distance d1 is always much larger than d2 and d3. Thus, an optimal choice of the constant amplitudes c, d, and e is one that provides d2≈d3 under the condition that PAPRB≈2.2 and EA=EB.
For example, if c=0.611617844·a, e=0.63 d3 a, and d=1.813520605 d3 a are selected, then a DS-CDMA system is obtained with PAPR≈2.2009 and d1≈2.992·a2, d2≈2.987·a2, d3≈3.1752·a2.
Decoding for the DS-CDMA System 300
For reconstruction of the variable b, we use exactly the same procedure as in system A. Since in systems B and C we keep the same amplitude for signals transmitted in the 0th stream as in system A, the probability of error remains also the same. For reconstruction information from other streams in systems B and C we can also use the same procedure of despreading as in system A. However, since signal amplitudes for streams 1, 2, . . . , 7 are lower than in system A, the bit error probability will increase. For this reason, in addition to despreading, a posteriori probability (APP) decoding of the received vector can be used.
It is again assumed that a vector b=(b0,b1, . . . , b7) is transmitted. The output vector
is transmitted through a noisy channel and the vector x=s+z is received. Without loss of generality, it is assumed that the channel is an additive white Gaussian noisy (AWGN) channel. In other words, it is assumed that the density function f(zi) of any element of the vector z can be expressed as:
where σ depends on the SNR of a channel.
1. For i from 0 to 7 compute
2. For all b=(b0,b1, . . . b7) from B compute
3. For i from 0 to 7 do
4. For i from 0 to 7 do
5. End.
Using standard arguments (see, e.g., L. R. Bahl et al., “Optimal Decoding of Linear Codes for Minimizing Symbol Error Rate,” IEEE Trans. Inform. Theory, 20, 284-87 (1974)), it can be shown that:
In other words, ti is the log likelihood ratio of the ith bit. The algorithm 600 requires about 1000 operations over real numbers.
It is to be understood that the embodiments and variations shown and described herein are merely illustrative of the principles of this invention and that various modifications may be implemented by those skilled in the art without departing from the scope and spirit of the invention.
Number | Name | Date | Kind |
---|---|---|---|
6310869 | Holtzman et al. | Oct 2001 | B1 |
6314107 | Shanbhag | Nov 2001 | B1 |
6389138 | Li et al. | May 2002 | B1 |
6563808 | Cox et al. | May 2003 | B1 |
6680978 | Schneider et al. | Jan 2004 | B1 |
7453954 | Wright et al. | Nov 2008 | B2 |
Number | Date | Country |
---|---|---|
1 359 678 | Nov 2003 | EP |
Entry |
---|
Ottosson, T., “Precoding for Minimization of Envelope Variations in Multicode DS-CDMA Systems,” Wireless Personal Communications, Kluwer Academic Publishers, NL vol. 13, No. 1/2, pp. 57-77 (May 2000). |
Murphy, C. D., “High-order Optimum Hexagonal Constellations,” Personal, Indoor and Mobile Radio Communications, 2000. PIMRC 2000. The 11th IEEE International Symposium, Piscataway, NJ, pp. 143-146 (Sep. 2000). |
Sathanathan et al., “Peak-to-Average power ratio analysis in multicode cdma,” 2002 IEEE 56th Vehicular Technology Conference Proceedings, Vancouver, Canada, vol. 1 of 4, pp. 500-504 (Sep. 2002). |
Davis et al., “Peak-to-Mean Power Control in OFDM, Golay Complementary Sequences, and Reed-Muller Codes”, IEEE Transaction on Information Theory, vol. 45, pp. 2397-2417 (Nov. 1999). |
Tadahiro Wada, “Characteristics of Bit Sequences Applicable to Constant Amplitude Orthogonal Multicode Systems”, IEICE Trans. Fundamentals, vol. E83-A, No. 11 (Nov. 2000). |
Kim et al., “Enhancement of Constant Amplitude Coding for Multicode Wideband CDMA Systems”, IEICE Trans. Commun., vol. E83-B, No. 11 (Nov. 2000). |
Number | Date | Country | |
---|---|---|---|
20050243895 A1 | Nov 2005 | US |