This invention relates to a communication system, and in particular to an orthogonal frequency division multiple access (OFDMA) communication system, in which each user has a frequency hopping scheme.
In an OFDMA system, the available frequency bandwidth is divided into a number of sub-channels, and these sub-channels can be allocated to different users of the system.
The document 3GPP 25.814 “Physical Layer Aspects for Evolved UTRA” v1.2.0 section 9.2.1, describes an uplink access scheme, in which each user can be allocated a variable bandwidth, formed from a number of contiguous sub-channels.
It is known that allowing frequency hopping is a way to improve the reliability of a communication system. That is, when a user is transmitting on one frequency at any given time, there is defined a sequence of frequency channels, and the user transmits on the channels of the defined sequence in turn.
However, this type of technique cannot be straightforwardly applied to a system in which variable bandwidths, and hence variable numbers of sub-channels, can be allocated to the different users, as it is a requirement that the same sub-channel should not be allocated to two different users at the same time. Moreover, it is also advantageous for the sub-channels allocated to each user to be consecutive.
According to a first aspect of the present invention, there is provided a method of allocating available bandwidth to one or more users.
According to other aspects of the invention, there are provided a network node, for performing the allocation method, and a user equipment, for operating on the allocated bandwidth.
For a better understanding of the present invention, and to show how it may be put into effect, reference will now be made, by way of example, to the accompanying drawings, in which:
It will be apparent to the person skilled in the art that the illustrated part of the communication system 10 may form part of a cellular wireless communication system, in which multiple base stations provide coverage to mobile user equipments within a network coverage area.
Within the first user equipment (UE) 20, data is generated in a conventional manner for transmission over a wireless communications link to the base station 15. In this illustrated case, N symbols of data are generated within one time period. The data is passed to a serial-parallel conversion block 30, where it is converted to parallel form, and then passed over N parallel lines numbered 0, 1, . . . , N−1 to a fast fourier transform (FFT) processing block 32, in which the data is transformed into the frequency domain.
The FFT output data is then passed to N contiguous inputs of an inverse fast fourier transform (IFFT) processing block 34, and converted back into a time domain signal. The IFFT output is then applied to a parallel-serial converter 36, for conversion into a serial data signal, and this signal is then applied to a cyclic prefix (CP) insertion block 38, for the addition of a cyclic prefix, in a manner that is known to the person skilled in the art.
Similarly, within the second user equipment (UE) 22, data is generated in a conventional manner for transmission over a wireless communications link to the base station 15. In this illustrated case, N symbols of data are generated within one time period. The data is passed to a serial-parallel conversion block 40, where it is converted to parallel form, and then passed over N parallel lines numbered 0, 1, . . . , N−1 to a fast fourier transform (FFT) processing block 42, in which the data is transformed into the frequency domain.
The FFT output data is then passed to N contiguous inputs of an inverse fast fourier transform (IFFT) processing block 44, and converted back into a time domain signal. The IFFT output is then applied to a parallel-serial converter 46, for conversion into a serial data signal, and this signal is then applied to a cyclic prefix (CP) insertion block 48, for the addition of a cyclic prefix.
It will thus be noted that, in this illustrated case, each of the two users is transmitting N symbols of data, and this data is mapped to respective groups of N contiguous inputs of the respective IFFT processing blocks 34, 44. In embodiments of the present invention, however, there may be more than two users, and the users may be transmitting different numbers of symbols of data per symbol period.
The respective groups of inputs of the respective IFFT processing blocks 34, 44, to which the data is mapped, correspond to the frequency sub-channels that have been allocated to that user. This allocation is performed in the network, for example in the base station 15, and the respective user equipments ensure that transmissions therefrom use the allocated sub-channels.
Thus,
As mentioned above, it would be advantageous to provide a system where a user is able to transmit on different sub-bands during different symbol periods.
In step 60, the available sub-channels are split into equally sized sub-bands at different levels.
In step 62, one of these sub-bands is allocated to a user, based on the bandwidth required by that user. At this stage, it is possible that the user requires the whole of the available bandwidth, in which case frequency hopping is not possible, and the remaining steps are not performed.
In step 64, at least one other sub-band is allocated to the user, with the other sub-band(s) being defined by means of a mathematical operator being applied to the first allocated sub-band.
In step 66, a frequency hopping sequence is defined, in which the allocated sub-bands are formed into a sequence.
In step 68, the user is informed of the defined frequency hopping sequence, which it should use for its future transmissions.
These steps will now be described in more detail.
Let sub-band j at level k be denoted by the binary representation:
f
j
(k)
=b
1
b
2
K b
k
so that:
b
1 2k'1+b2 2k−230 K+bk−1 21+bk=j
and where bi=0 or 1.
As discussed with reference to step 62 of the process shown in
Now, introduce the basic “flip” operator σi, acting on level i, by:
σifj(k)=fj(k)⊕1i(k),
in which ⊕ denotes bitwise addition modulo 2 (i.e. the binary exclusive-or operation) and where 1i(k):=2k−i.
As an example:
with f25(6)=011001 we get σ3f25(6)=011001β001000=010001.
Note that repeated flip operation retrieves the original sub-band, i.e.
σi2:=σiσi=I.
where I is the identity operator, and so, in addition, we can define:
σi0:=I.
Thus, the flip operator acting on sub-band 0 (000 in binary representation) at level 3 generates the new sub-band 1 (001 in binary representation). Meanwhile, the flip operator acting on sub-band 1 (001 in binary representation) at level 3 generates the new sub-band 0 (000 in binary representation). This means that, if the sub-bands 0 and 1 are allocated to different users, this operate will exchange, or flip, those allocations.
Associated with the flip operator σi acting on level i is a shift 0j(k) at level k such that sub-band j is shifted to sub-band j′ with the magnitude of the shift |j′−j|=2k−i.
Expressed more formally, the flip results in a shift to
σifj(k)=fj′(k) where j′=j+θi(k)(j)
with θi(k)(j)=s(i,k;j)·d(k,i),
s(i,k;j)=(−1)[jld(k,i)] the sign of the shift, and d(k,i)=2k−i is the magnitude of the shift.
The argument j is the current sub-band and it determines whether the shift is positive or negative.
This means that that sub-band j on level k is shifted to sub-band j′=j+2k−i if j<2k−i and j′=j−2k−i otherwise.
Thus,
The level 2 sub-band therefore occupies one quarter of the total bandwidth, specifically the lower half of the lower half of the available sub-channels. After the mathematical flip, or shift, operation, there is defined a new sub-band, again occupying one quarter of the total bandwidth, specifically now the upper half of the lower half of the available sub-channels.
The level 3 sub-band 85 therefore occupies one eighth of the total bandwidth, specifically the upper half of the third quarter of the available sub-channels. After the mathematical flip, or shift, operation, there is defined a new sub-band, again occupying one eighth of the total bandwidth, specifically now the lower half of the third quarter of the available sub-channels.
The level 3 sub-band 86 therefore occupies one eighth of the total bandwidth, specifically the lower half of the fourth quarter of the available sub-channels. After the mathematical flip, or shift, operation, there is defined a new sub-band, again occupying one eighth of the total bandwidth, specifically now the upper half of the fourth quarter of the available sub-channels.
Once the other sub-band has been allocated to the user, as a result of this operation, a hopping sequence is defined. In particular, a sub-band (level k) hopping sequence F(k)(t),t=1, 2, 3, K for a connection is formed by assigning the connection the following set of parameters:
Unless otherwise stated, it is assumed that the assigned sub-bands for hopping by a connection are different, i.e. i≠j (otherwise we have the trivial case without hopping).
The hopping sequence, in terms of flipping, is then constructed by:
F
(k)(t)=σzx(t)F(k)(t−1) (1)
F
(k)(0)=fi(k) (2)
and where the level of the flip, z, is given by
z=k−log2|j−i|. (3)
In terms of shifting, the hopping sequence is given by:
F
(k)(t)=F(k)(t−1)+x(t)·θz(k)(F(k)(t−1)) (4)
F
(k)(0)=fi(k). (5)
Note that this imposes a restriction of the pairs of sub-bands that may be assigned. It is required that log2|j−i| is an integer, or equivalently that the magnitude of the shift |j−i| is an integer power of 2.
Alternatively but equivalently, a connection is assigned a hopping sequence by
It is also possible to use a combined flip operator, that can be used in exactly the same way as the basic single-level flipping in the preceding section, by combining two or more basic flip operators operating at different levels, e.g.
σij=σiσj.
This should be interpreted as
σijfI(k)=σi(σjfI(k)).
Note that σij=σji and that the necessary property σij2=I holds.
The corresponding combined sub-band shift is given by
θiij(k)=θii(k)+θij(k).
This should be interpreted as the shift from sub-band I on level k to sub-band
I+θi
ij
(k)
=I+θi
i
(k)(I)+θij(k)(I).
This can be generalized to combined flipping on any number of levels. Note that flipping must occur simultaneously on all levels where flipping is applied.
As illustrated above, the different users, or connections, have different bandwidth requirements and so the bandwidth allocations are variable. This has the result that sub-band allocation and sub-band hopping have to be done at different levels of the sub-band tree in order to ensure unfragmented sub-bands; provide sub-band hopping at various levels; maintain sub-band hopping restrictions, i.e. at most 2 sub-bands per connection; and avoid collisions.
These requirements can be met by allocating disjoint resources from the same sub-band tree; applying the same flip (or no flip) at a certain level for all connections that are affected by this flip, i.e. connections sharing the same sub-branch in the sub-band tree for which the flip is applied. It should also be noted that, if flipping is applied at more than one level along a branch, flipping must be applied simultaneously at all levels.
This has the result that only one binary sequence is needed for a connection to generate flips (or shifts) on the various levels in case of combined flipping.
The examples given so far assume that a connection, or a user, has a bandwidth requirement that is an exact binary fraction (i.e. ½a, where a is an integer) of the available bandwidth. A connection requesting n, where 2k−1<n<2k , sub-band units (i.e. where a sub-band unit is the smallest sub-band into which the sub-channels have been divided) can be treated as a connection requesting 2k sub-band units with respect to sub-band hopping assignment.
The invention has been described so far with reference to binary splitting of the available sub-bands, and flipping using an operator that returns to the original sub-band after two applications, and hence the generation of hopping sequences that contain two sub-bands. However, this can be generalized to allow hopping on more than 2 sub-bands in a similar way by n-state flipping.
In this case, we can assume that the available bandwidth has a n-ary splitting into equally sized sub-bands. At level k=1, the carrier is split into n sub-bands. At an arbitrary level k, the carrier is split into nk sub-bands, each numbered as 0, 1, . . . , nk−1. Let sub-band j at level k be denoted by the representation:
f
j
(k)=
b
1
b
2
K b
k
so that b1nk−+b2nk−2+K+bk−1n1+bk−j
and where bi ε{0, 1, K, n−1}.
Now, we introduce the basic “flip” operator σi acting on level 1, by
σifj(k)=fj(k)⊕1k(k)
in which ⊕ denotes bitwise addition modulo n and where 1i(k):=nk−i.
For example:
With n=3 and f25(4)=0221 we get:
σ3f25(4)=0221⊕0010=0201=f19(4),
i.e. a shift from sub-band 25 to 19.
The next flip yields:
σ3f19(4)=0201⊕0010=0211=f23(4),
i.e. a shift from sub-band 19 to 22.
The third flip results in the original sub-band.
Note that repeated flip operation retrieves the original sub-band, i.e. σin:=σiΛσi=I where I is the identity operator.
A connection is assigned a hopping sequence in this case by:
The hopping sequence, in terms of flipping, is then constructed by
F
(k)(t)=σzx(t)F(k)(t−1) (6)
F
(k)(0)=fi(k) (7)
As described so far, there is provided a system in which the available bandwidth is divided in a predetermined way, and this is suitable for many applications. However, in other situations, it may be desirable to allow an adaptive allocation of the available frequency resources.
Specifically,
In step 120, a new user registers with the system, and in step 122 it is determined in one of the network nodes what bandwidth is required by that user. As before, the allocation of sub-channels can be performed in any network node. The information about the allocated sub-channels, and the frequency hopping sequence, can be performed in that network node, and then informed to the other network node or nodes involved in the connection by means of a relatively short information-carrying message.
This embodiment of the invention will be described with reference to a situation in which there are 31 sub-channels available for allocation to the users.
In step 124, the required bandwidth is used to determine how many of the available sub-channels should be allocated to that user and, in step 126, the required number of sub-channels is allocated for a first time period, t. In this illustrated embodiment, a group of consecutive sub-channels is allocated to the user, either starting at the first (lowest numbered) of said frequency sub-channels that have not previously been allocated to another user, or ending at the last (highest numbered) of said frequency sub-channels that have not previously been allocated to another user.
In step 128, an allocation level is set for that user. In one embodiment of the invention, the allocation levels can be applied simply in numerical order. Thus, the first user is given allocation level 1, the second user is given allocation level 2, and so on, with each new user being given an allocation level that is greater by 1 than the number of already allocated users.
However, in another embodiment, a new user is given an allocation level that is greater by 1 than the number of already allocated users, only if the bandwidth allocated to the new user is smaller than the bandwidth allocated to any other user. If, in fact, there is one or more of the already allocated users with a smaller bandwidth allocation than the new user, then the new user is given the allocation level of that already allocated user, and the allocation level of each of the already allocated users is increased by 1. In yet another embodiment of the invention, if there is one or more of the already allocated users with a smaller bandwidth allocation than the new user or the same bandwidth allocation as the new user, then the new user is given the allocation level of that already allocated user, and the allocation level of each of the already allocated users is increased by 1.
In step 130, a permutation operator is defined for the user and, in step 132, a complementary permutation operator is defined, as will be described in more detail below. The process passes to step 134, in which it is determined if all users have been dealt with. If not, the process returns to step 120 but, if so, the process passes to step 136.
The first user, u1, requires 4 sub-channels, and is allocated the sub-channels starting at the lowest numbered available sub-channel (that is, sub-channel 0), and is therefore allocated sub-channels 0, 1, 2, 3. The first user is also given allocation level 1.
The second user, u2, requires 22 sub-channels, and is allocated the sub-channels ending at the highest numbered available sub-channel (that is, sub-channel 30), and is therefore allocated sub-channels 9, 10, 11, . . . , 30. As the second user has a larger bandwidth allocation than the first user, the second user is now given allocation level 1, while the first user is reallocated to allocation level 2.
The third user, u3, requires 2 sub-channels, and is allocated the sub-channels starting at the lowest numbered available sub-channel (that is, sub-channel 4), and is therefore allocated sub-channels 4 and 5. The third user is also given allocation level 3.
The fourth user, u4, requires 2 sub-channels, and is allocated sub-channels 4, 5. In this embodiment, a new user is given an allocation level that has previously been given to another user, only if the new user has a larger bandwidth allocation than that previous user (and not if the new user has the same bandwidth allocation as the previous user), and so the fourth user is now given allocation level 4.
The fifth user, u5, requires 1 sub-channel, and is allocated the remaining sub-channel, namely sub-channel 8. The fifth user is also given allocation level 5.
In steps 130 and 132, a permutation operator and a complementary permutation operator are defined for the user.
The effect of the permutation operator is that, for each user, when the allocated group of consecutive sub-channels starts at the lowest numbered of said frequency sub-channels that have not been allocated to another user at a lower allocation level, the sub-channel number of each of said sub-channels is increased by a first number such that the group ends at the highest numbered of said frequency sub-channels that have not previously been allocated to another user at a lower allocation level. When the allocated group of consecutive sub-channels ends at the highest numbered of said frequency sub-channels that have not previously been allocated to another user at a lower allocation level, the sub-channel number of each of said sub-channels is decreased by the first number such that the group starts at the lowest numbered of said frequency sub-channels that have not been allocated to another user at a lower allocation level.
The effect of the complementary permutation operator is that, for each user, when the non-allocated group of consecutive sub-channels starts at the lowest numbered of said frequency sub-channels that have not previously been allocated to another user at a lower allocation level, the sub-channel number of each of said sub-channels is increased a by a second number such that the group ends at the highest numbered of said frequency sub-channels that have not previously been allocated to another user at a lower allocation level. When the non-allocated group of consecutive sub-channels ends at the highest numbered of said frequency sub-channels that have not previously been allocated to another user at a lower allocation level, the sub-channel number of each of said sub-channels is decreased by the second number such that the group starts at the lowest numbered of said frequency sub-channels that have not previously been allocated to another user at a lower allocation level.
Thus, in the case illustrated in
The permutation operators and complementary permutation operators can be expressed mathematically, as follows. In this explanation, the sub-channels in the frequency band are indexed as 0, 1, 2, . . . corresponding to the increasing sequence of physical sub-channel frequencies (although these indices could equally apply to the decreasing sequence of physical sub-channel frequencies), and each user is associated with an allocation level in the allocation tree (as shown in
At allocation level k, there are n(k) available sub-channels, with F0(k) being the lowest index of the available sub-channels. Of those available sub-channels, a sub-band of n1(k) sub-channels is allocated. If this sub-band starts at the lowest numbered of said available sub-channels, it includes the sub-channels F0(k) to (F0(k)+n1(k)−1). If the sub-band ends at the highest numbered of said available sub-channels, it includes the sub-channels (F0(k)+n(k)−n1(k)) to (F0(k)+n(k)−1).
If f1 is the index of one of the allocated sub-channels, and f′1 is the index of one of the remaining non-allocated sub-channels, then the permutation operator σk operating in the allocated sub-band, and the complementary permutation operator σ′k operating in the non-allocated sub-band are defined as follows:
The process then determines a second sub-channel allocation, by using the permutation operators and the complementary permutation operators.
In step 136, a new allocation level is considered, starting at allocation level 1 and, in step 138, it is determined whether all of the levels have been considered. Assuming that there are levels still to consider, the process passes to step 140, in which it is determined whether the current allocation level is allocation level 1. If so, step 142 is omitted but, otherwise, the process passes to step 142.
In step 142, the complementary permutation operator for each preceding level is applied to the sub-channel numbers allocated to the user having the current allocation level.
The process then passes to step 144, in which the permutation operator for the current allocation level is applied to the sub-channel numbers allocated to the user at that allocation level.
After applying the permutation operator, the process passes to step 136, for consideration of a different allocation level.
Thus, at allocation level 1, the permutation operator for allocation level 1 is applied, decreasing each sub-channel number by 9. Thus, sub-channel numbers 9, 10, 11, . . . , 30 are permuted to sub-channel numbers 0, 1, 2, . . . , 21.
At allocation level 2, the complementary permutation operator for allocation level 1 is applied, increasing each sub-channel number by 22, and then the permutation operator for allocation level 2 is applied, increasing each sub-channel number by 5. Thus, sub-channel numbers 0, 1, 2, 3 are permuted to sub-channel numbers 28, 29, 30, 31.
At allocation level 3, the complementary permutation operators for allocation levels 1 and 2 are applied, increasing each sub-channel number by 22, and then decreasing each sub-channel number by 4, and then the permutation operator for allocation level 3 is applied, increasing each sub-channel number by 3. Thus, sub-channel numbers 4, 5 are permuted to sub-channel numbers 25, 26.
At allocation level 4, the complementary permutation operators for allocation levels 1, 2 and 3 are applied, increasing each sub-channel number by 22, and then decreasing each sub-channel number by 4, and decreasing each sub-channel number by 2, and then the permutation operator for allocation level 4 is applied, increasing each sub-channel number by 1. Thus, sub-channel numbers 6, 7 are permuted to sub-channel numbers 23, 24.
At allocation level 5, the complementary permutation operators for allocation levels 1, 2 3 and 4 are applied, although no permutation is possible, and so sub-channel number 8 is permuted to sub-channel number 22.
There are thus defined two frequency allocations. In one embodiment of the invention, these two frequency allocations can be used during different time periods in a frequency hopping sequence. If the first allocation is represented by a binary “0”, and the second is represented by a binary “1”, then any multi-digit binary number can represent a frequency hopping sequence, with the bit values of the binary number indicating which of the frequency allocations should be used during successive time periods.
It will be appreciated that other allocations can be defined according to the method set out above. For example, during a second time interval TTI2, including time periods tb1, tb2, tb5, a different first allocation is using during time periods tb3 and tb4, while a corresponding different second allocation is used during time periods tb1, tb2 and tb5, so this sequence can be represented by the binary number 11001.
In further embodiments according to the present invention, once permutation operators have been determined on all levels, frequency hopping sequences can be constructed by, for each time step, either applying, or not applying, permutation operations on the various levels. Permutation operations may be applied independently on different levels, unless frequency hopping is constrained to a limited number of sub-bands per user. For n users there will be n levels in the frequency hopping tree. All possible combinations of applying or not applying permutations on the various levels yield up to 2n different combinations of sub-band allocations available for the frequency hopping.
The frequency hopping sequences can be defined by specifying a binary sequence for each level (i.e. a total of n binary sequences), in which a binary digit indicates the operation to be performed (for example 0: no permutation or transition; 1: permutation, i.e. transition from “right” to “left” or “left” to right“). The frequency hopping sequence on level k is obtained by, for each time step, combining the permutations on levels 1 through k. Alternatively but equivalently, a binary sequence may indicate the state on level k (0: “left”; 1: “right”) for each time step, rather than the event of permutation. The frequency hopping sequence on level k is then obtained by, for each time step, combining the states on levels 1 through k. Thus, a frequency hopping sequence can be specified as a sequence of binary vectors v1,v2,v3, . . . , where each vector has n binary digits, each one corresponding to a level in the frequency hopping tree.
The important special case of constrained frequency hopping on at most N distinct sub-bands per user imposes restrictions. This means that of a total of 2n combinations of available sub-band allocations in the frequency hopping tree consisting of n levels, at most N combinations may be used. If N equals 2 (as in the example), permutations on all levels (on which permutations are ever applied) must occur simultaneously. In this case, a binary frequency hopping sequence can be defined as a scalar binary sequence valid for all levels. The frequency hopping sequence is specified either as a binary sequence of transitions, or as a sequence of binary states.
In general, hopping sequences with constraints on number of sub-bands can be pre-defined and stored in the nodes involved in frequency hopping.
There is thus described a method for generating a single-carrier frequency sequence, in which the transmissions may hop over only a few of the available frequency sub-bands. The hopping patterns within a cell are orthogonal and offer frequency and interference diversity. The proposed scheme is further resource efficient since it facilitates that all time-frequency resources (in a cell) may be in use simultaneously.
The invention would be applicable e.g. in systems using variable bandwidth single-carrier transmission, like the proposed 3GPP LTE uplink access scheme.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/SE07/50110 | 2/23/2007 | WO | 00 | 8/20/2009 |