Methods and apparatus for code division multiple access communication using code book that provides reduced peak-to-average power ratio

Information

  • Patent Grant
  • 9094144
  • Patent Number
    9,094,144
  • Date Filed
    Thursday, April 29, 2004
    20 years ago
  • Date Issued
    Tuesday, July 28, 2015
    9 years ago
Abstract
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. An 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. 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.
Description
FIELD OF THE INVENTION

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).


BACKGROUND OF THE INVENTION

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.


SUMMARY OF THE INVENTION

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.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates a conventional DS-CDMA system;



FIG. 2 illustrates an exemplary code book that can be employed by the DS-CDMA system of FIG. 1;



FIG. 3 illustrates a DS-CDMA system incorporating features of the present invention;



FIG. 4 is a flow chart describing an exemplary implementation of a code book generation process;



FIG. 5 is a plot illustrating the relative decoding performance (bit error probability versus signal-to-noise ratio) of the conventional DS-CDMA system of FIG. 1 and the DS-CDMA system of FIG. 3, in the presence of an additive white Gaussian noisy (AWGN) channel; and



FIG. 6 is a flow chart describing an exemplary implementation of a decoding process.





DETAILED DESCRIPTION


FIG. 1 illustrates a conventional DS-CDMA system 100 with a spreading factor (SF) of four (4). The conventional DS-CDMA system 100 is used, for example, in mobile telephones. For a detailed discussion of exemplary DS-CDMA systems 100, see, for example, T. Ottosson, “Precoding for Minimization of Envelope Variations in Multicode DS-CDMA Systems,” Wireless Personal Communications, 13, 57-78 (2000), incorporated by reference herein.


The conventional DS-CDMA system 100 shown in FIG. 1 is used for simultaneous transmission of four streams of information, a0,a1,a2 and a3, that carry information of streams 0, 1, 2, and 3, respectively. Variables a0,a1,a2 and a3 form the vector a=(a0,a1,a2,a3). The vector s is referred to as the output vector that is applied to a communications channel. The vectors c0, c1, c2 and c3 are spreading sequences. Generally, each information stream a0,a1,a2 and a3 is multiplied by a corresponding spreading sequence, c0, c1, c2 and c3, respectively, by corresponding multipliers 110-1 through 110-4, and the spread signals are combined at stage 120 prior to application to the channel.



FIG. 2 illustrates an exemplary code book A 200 that can be employed by the DS-CDMA system 100 of FIG. 1. Thus, the vectors a form the code book A of FIG. 2. The information bit from the ith information stream is encoded into the sign of the ith entry of a vector a. The logical zeroes (0s) correspond to positive entries of a vector a and logical ones (1s) correspond to negative entries. For example, in order to transmit logical zero in the 0th and 3rd information streams and logical one in the 1st and 2nd streams, the vector a=(a,−a,−a,a) is transmitted. The value a is the amplitude of transmitted signals. Typically, the amplitudes of each of the four streams of information, a0,a1,a2 and a3, are the same. In some implementations of the conventional DS-CDMA system 100, the amplitude of one or more of the four streams of information, a0,a1,a2 and a3, may be increased to provide a corresponding increase in energy (and thus protection) of the stream. For example, the amplitude of stream a0, which may be associated with a pilot signal, may be increased to improve the channel estimation.


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:

    • c0=(1, 1, 1, 1),
    • c1=(1, −1, 1, −1),
    • c2=(1, 1, −1, −1),
    • c3=(1, −1, −1, 1).


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:








H
4

=

[




1
,




1
,




1
,



1





1
,





-
1

,




1
,




-
1






1
,




1
,





-
1

,




-
1






1
,





-
1

,





-
1

,



1



]


,





and therefore they are orthogonal. In other words












c
_

i

·


c
_

j


=

{




4
,



if




i
=
j

;






0
,



if




i

j

;









(
1
)








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 FIG. 1, with the spreading factor of four, variables a0,a1,a2 and a3 cannot change their values faster than every four consecutive chips.


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:










R
A

=




3


m
4


+
1

m

.





(
2
)







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+zci=(a0c0+a1c1+a2c2+a3c3ci+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:








h
0

=





i
=
1


m
/
4






x
_


(
i
)


·


c
_

0



=





i
=
1


m
/
4







j
=
0

3




x
_

j

(
i
)




=

ma
+




i
=
1


m
/
4







j
=
0

3




z
_

j

(
i
)








,





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:








E
av



(

s
_

)


=


1
4




(


s
0
2

+

s
1
2

+

s
2
2

+

s
3
2


)

.






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 FIG. 2.










E
A

=


1
16






s
-






E
av



(
s
)


.







(
4
)







The peak energy of s is defined as











E
peak



(

s
_

)


=


max

0

i

3





{

s
i
2

}

.






(
5
)







The peak to average power ratio of the DS-CDMA system 100 equals:










PAPR
A

=


max

s
-







E
peak



(

s
_

)



E
A


.






(
6
)








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:











E
av



(

s
_

)


=



1
4



(


s
0
2

+

s
1
2

+

s
2
2

+

s
3
2


)


=



1
4


4


(


a
0
2

+

a
1
2

+

a
2
2

+

a
3
2


)


=

4



a
2

.








(
8
)







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:







PAPR
A

=




(

4

a

)

2


4


a
2



=
4.





Improved DS-CDMA System



FIG. 3 illustrates a DS-CDMA system 300 incorporating features of the present invention. The exemplary DS-CDMA system 300 provides a spreading factor SF=8, with a reduced peak to average power ratio and bit error probability, relative to the conventional DS-CDMA system 100. In various implementations, the DS-CDMA system 300 can have the same (i) rate, (ii) average energy per chip and (iii) amplitude, a, of signals transmitted in the 0th stream as the conventional DS-CDMA system 100. In this manner, the rate of the conventional system is maintained without increasing the average power per chip. In addition, the power for signals transmitted in the 0th stream is not changed, thereby resulting in the same bit error probability. Since the 0th stream plays a special role in the system it can be important to maintain the bit error probability for the 0th stream, relative to the DS-CDMA system 100. For example, if the 0th stream is used for sending a pilot signal and the amplitude of the signal is reduced, this will result in a less accurate estimate of the channel fading coefficients, which, in turn, leads to failure to decode other streams of information.


Vectors b=(b0, b1, b2, b3, b4, b5, b6, b7) are taken from the code book, defined below in conjunction with FIG. 4. In the exemplary implementation, only streams 0, 1, . . . , 6 carry information and stream 7 plays an auxiliary role. The signs (polarities) of the variables b0, . . . , b6 represent values of transmitted bits, in a similar manner to the DS-CDMA system 100. For example, positive entries can correspond to logical 0 and negative entries can correspond to logical 1. The absolute values |b0|, . . . , |b7| represent signal amplitudes of transmitted signals. In the DS-CDMA system 300 of the present invention, different amplitudes and polarities are chosen for signals from different streams (such that a desired average energy, EA, is maintained).


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







6


m
8


+
1





bits of information and therefore the rate of the DS-CDMA system 300 equals the rate of the conventional DS-CDMA system 100:







R
B

=





6
8


m

+
1

m

=





3
4


m

+
1

m

=


R
A

.







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:








G
pc

=

[



1


1


1


1


1


1


1


1




0


1


0


1


0


1


0


1




0


0


1


1


0


0


1


1




0


0


0


0


1


1


1


1




0


0


0


0


1


0


0


1




0


0


0


0


0


1


0


1




0


0


0


0


0


0


1


1



]


,






G
rm

=


[



1


1


1


1


1


1


1


1




0


1


0


1


0


1


0


1




0


0


1


1


0


0


1


1




0


0


0


0


1


1


1


1



]

.






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 FIG. 4:


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







E
vector

=




112


(


a
2

+

7


c
2



)


+

16


(

a
+

6



2


+

d
2


)



128

.





Using the Parseval rule of equation (7), the average energy per chip is expressed as follows:










E
B

=



1
8


8


E
vector


=




112


(


a
2

+

7


c
2



)


+

16


(

a
+

6



2


+

d
2


)



128

.






(
10
)







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:










PAPR
B

=



max


{








a
+

3

c




2

,




a
-
c



2

,




a
-

5

c




2

,









a
+

6

e

-
d



,



a
+
d



,



a
-

2

e

-
d







}





112


(


a
2

+

7


c
2



)


+

16


(

a
+

6



2


+

d
2


)



128


.





(
11
)







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








(




a
,




e
,




e
,




e
,




e
,




e
,




e
,




-
d






a
,





-
e

,





-
e

,




e
,




e
,





-
e

,





-
e

,



d



)






will have the minimum pairwise distance, say d1, among all pairs of vectors of the first type. Similarly, the vectors of the following form:








(




a
,




c
,




c
,




c
,




c
,




c
,





-
c

,




-
c






a
,




c
,




c
,




c
,




c
,





-
c

,





-
c

,



c



)






will have the minimum pairwise distance, say d2, among all pairs of vectors of the second type.


Finally, the vectors of the folllowing form:








(




a
,




e
,




e
,




e
,




e
,




e
,




e
,




-
d






a
,




c
,




c
,




c
,




c
,




c
,





-
c

,




-
c




)






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.



FIG. 5 is a plot 500 illustrating the relative decoding performance (bit error probability versus signal-to-noise ratio) of the conventional DS-CDMA system 100 and the DS-CDMA system 300 of the present invention, in the presence of an additive white Gaussian noisy (AWGN) channel. According to another aspect of the invention, two different code books are employed based on whether the channel exhibits low or high signal to noise ratios (SNR), distinguished by a specified threshold. Thus, to minimize 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. For example, as shown in FIG. 5, for a SNR above 2, the codebook associated with the DS-CDMA system 300 of FIG. 3 will exhibit a better bit error probability.


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







s
_

=




i
=
0

7




b
i




w
_

i








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:








f


(

z
i

)


=


1


2





π






σ
2









z
i
2


2






σ
2






,





where σ depends on the SNR of a channel.



FIG. 6 is a flow chart describing an exemplary decoding process 600. As shown in FIG. 6, the exemplary decoding process 600 performs as follows:


1. For i from 0 to 7 compute








y
i

=


x
_

·


w
i

_



;




2. For all b=(b0,b1, . . . b7) from B compute







p


(

b
_

)


=

exp


(





(


y
0

-

b
0


)

2

+


(


y
1

-

b
1


)

2

+

+


(


y
7

-

b
7


)

2


)


2






σ
2



)






3. For i from 0 to 7 do











t
i

(
0
)


=





b
_

=



(


b
0

,









,

b
7


)

:

b
i


=
1





p


(

b
_

)




,








t
i

(
1
)


=





b
_

=



(


b
0

,









,

b
7


)

:

b
i


=

-
1






p


(

b
_

)




,







t
i

=

ln



t
i

(
0
)



t
i

(
1
)











4. For i from 0 to 7 do








b
^

i

=

{




1
,



if





t
i

>
0

;







-
1

,



if




t
i

<
0.









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:







t





i


=



Pr


(


sign


(

b
i

)


=

1
|

x
_



)



Pr


(


sign


(

b
i

)


=


-
1

|

x
_



)



.





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.

Claims
  • 1. A method for generating a code book for use in a CDMA system, said code book comprised of a plurality of vectors, said method comprising: selecting an amplitude and polarity value for each vector of said code book to provide a reduced peak-to-average power ratio for transmissions that include data transmissions comprising one or more data symbols, wherein each vector in said code book depends on transmitted user data, wherein each vector in said code book depends on transmitted user data by generating a vector v by multiplying said transmitted user data by a generator matrix and using said vector v in the formation of each of said vectors in said code book.
  • 2. The method of claim 1, wherein said CDMA system has a spreading factor of eight and eight distinct data streams.
  • 3. The method of claim 2, wherein one of said data streams is slowly varying and at least six of said data streams are employed to carry user information.
  • 4. The method of claim 3, wherein one or more of said data streams is reserved to maintain a desired data rate of said CDMA system.
  • 5. The method of claim 4, wherein said desired data rate is based on a date rate of a CDMA system having a lower order spreading factor.
  • 6. The method of claim 1, wherein said amplitude values are selected to maintain a desired energy per chip.
  • 7. The method of claim 6, wherein said desired energy per chip is based on an energy per chip of a CDMA system having a lower order spreading factor.
  • 8. The method of claim 1, further comprising the step of maintaining a desired data rate of said CDMA system.
  • 9. The method of claim 1, wherein said selecting step further comprises the steps of selecting said amplitude values to provide said reduced peak-to-average power ratio while maintaining a desired average energy per chip.
  • 10. The method of claim 1, further comprising the steps of generating a first code book to be used under a first signal-to-noise ratio condition and generating a second code book to be used under a second signal-to-noise ratio condition.
  • 11. A transmitter in a CDMA system, comprising: a plurality of multipliers, each of said multipliers multiplying an encoded data stream by a corresponding spreading code, wherein said encoded data stream depends on transmitted user data and is based on a code book comprised of a plurality of vectors, each of said vectors having non-uniform amplitude values selected to provide a reduced peak-to-average power ratio for transmissions that include data transmissions comprising one or more data symbols, wherein said encoded data stream depends on transmitted user data by generating a vector v by multiplying said transmitted user data by a generator matrix and using said vector v in the formation of each of said vectors in said code book; anda combiner for aggregating an output of each of said plurality of multipliers for transmission.
  • 12. The transmitter of claim 11, wherein said CDMA system has a spreading factor of eight and eight distinct data streams.
  • 13. The transmitter of claim 12, wherein one of said data streams is slowly varying and at least six of said data streams are employed to carry user information.
  • 14. The transmitter of claim 13, wherein one or more of said data streams is reserved to maintain a desired data rate of said CDMA system.
  • 15. The transmitter of claim 11, wherein said amplitude values are selected to maintain a desired energy per chip.
  • 16. The transmitter of claim 11, wherein said amplitude values provide said reduced peak-to-average power ratio while said transmitter maintains a desired average energy per chip.
  • 17. The transmitter of claim 11, wherein said encoded data stream is based on a first code book to be used under a first signal-to-noise ratio condition and a second code book to be used under a second signal-to-noise ratio condition.
  • 18. A system for generating a code book for use in a CDMA system, said code book comprised of a plurality of vectors, said system comprising: a memory; andat least one processor, coupled to the memory, operative to:select an amplitude and polarity for each vector of said code book to provide a reduced peak-to-average power ratio for transmissions that include data transmissions comprising one or more data symbols, wherein each vector in said code book depends on transmitted user data, wherein each vector in said code book depends on transmitted user data by generating a vector v by multiplying said transmitted user data by a generator matrix and using said vector v in the formation of each of said vectors in said code book.
  • 19. The system of claim 18, wherein one or more of said data streams is reserved to maintain a desired data rate of said CDMA system.
  • 20. The system of claim 18, wherein said amplitude values are selected to maintain a desired energy per chip.
  • 21. The system of claim 20, wherein said desired energy per chip is based on an energy per chip of a CDMA system having a lower order spreading factor.
  • 22. The system of claim 18, wherein said processor is further configured to maintain a desired data rate of said CDMA system.
  • 23. The system of claim 18, wherein said processor is further configured to select said amplitude values to provide said reduced peak-to-average power ratio while maintaining a desired average energy per chip.
  • 24. The system of claim 18, wherein said processor is further configured to generate a first code book to be used under a first signal-to-noise ratio condition and generate a second code book to be used under a second signal-to-noise ratio condition.
  • 25. A communication method, comprising: encoding a data stream based on transmitted user data and a code book comprised of a plurality of vectors, each of said vectors having coefficient values that provide a reduced peak-to-average power ratio for transmissions that include data transmissions comprising one or more data symbols relative to a peak-to-average power ratio that would result if said vectors contained coefficient values of uniform magnitude, wherein said step of encoding a data stream based on transmitted user data further comprises the steps of generating a vector v by multiplying said transmitted user data by a generator matrix and using said vector v in the formation of each of said vectors in said code book.
  • 26. The method of claim 25, further comprising the step of transmitting said encoded data stream.
  • 27. The method of claim 25, further comprising the step of multiplying said encoded data stream by a corresponding spreading code.
  • 28. The method of claim 25, wherein said encoded data stream is based on a first code book to be used under a first signal-to-noise ratio condition and a second code book to be used under a second signal-to-noise ratio condition.
US Referenced Citations (6)
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
Foreign Referenced Citations (1)
Number Date Country
1 359 678 Nov 2003 EP
Non-Patent Literature Citations (6)
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).
Related Publications (1)
Number Date Country
20050243895 A1 Nov 2005 US