The present invention relates to the field of mobile telecommunications and more particularly that of the reduction of interference in a femto-cellular network.
The communications in a femto-cellular network can be affected by interference generated by the communications of a neighbouring macro-cell.
In order to eliminate interference, it is essential to determine the scrambling code used on the uplink of the terminal 130. In fact, there does not exist in the literature an algorithm of multi-user detection in blind mode that can disregard the scrambling code. Detection in blind mode is taken to mean that the femto-cellular base station 120 does not receive information from the macro-cell and particularly not the transmission parameters of the different users of the macro-cell.
On the other hand, since the scrambling code is known, it is possible to estimate locally the signal received from the terminal 130 and to subtract its contribution in the receiver of the terminal 120.
When the macro-cellular network is of the WCDMA type, the determination in blind mode is made even more complex by the fact that each user of said system uses a specific scrambling code. Moreover, the signal transmitted by the user being spectrally spread, the estimation of the scrambling code must be carried out at low signal to noise level.
An aim of the present invention is to propose a method for determining a scrambling code used by an uplink of a WCDMA system, for example to eliminate the interference generated in a neighbouring femto-cell.
The present invention is defined as a scrambling code estimation method used on an uplink of a terminal in a WCDMA system, the signal transmitted by the terminal on said link being transmitted in the form of frames and scrambled by means of the scrambling code, the scrambling code being constructed from a Gold sequence (zn) obtained as sum of a first (xn) and of a second (y) sequences of maximal length, in which:
Advantageously, one verifies that the receiver is well synchronised with respect to the scrambling code by:
In the differential processing, the differential values are obtained by v(k)=−Im(u(2k)) with u(2k)=r(2k+1)r(2k)* where r(2k), r(2k+1) are successive samples of the signal received.
The decimated and shifted version, {tilde over (y)}, of the second sequence is obtained from the second sequence y by means of:
{tilde over (y)}(k)=y(2k)+y(2k+1)+y(2k+4)+y(2k+6)+y(2k+17).
Advantageously, said iterative decoding is a decoding by passing belief messages between nodes of variables and nodes of constraints, said constraints being supplied by the generator polynomial of the first sequence.
The scrambling code is advantageously estimated by:
The invention relates to, in a second embodiment, a scrambling code estimation method used on an uplink of a terminal in a WCDMA system, the signal transmitted by the terminal on said link being transmitted in the form of frames and scrambled by means of the scrambling code, the scrambling code being constructed from a Gold sequence (zn) obtained as sum of a first (xn) and of a second (y) sequences of maximal length, in which:
The content (SRGala) of the shift register of the generator of the third sequence according to a Galois representation may be determined from the content (SRFiba) of the shift register of said generator in a Fibonacci representation, said content being itself obtained as the list of the first bits of the third sequence.
One deduces advantageously from the content of the register of the generator of the second sequence, at the start of frame, and from the content of this same register, determined at the instant of measure, a shift of said instant of measure with respect to the start of frame.
Other characteristics and advantages of the invention will become clear on reading embodiments of the invention made with reference to the appended figures, among which:
The basic idea of the invention is to perform a blind estimation of the scrambling code from a differential multiplication of successive samples of the signal received.
Before precisely describing this blind estimation method, it should be recalled how transmission is carried out on an uplink of a WCDMA system.
The uplink is constituted of a data channel, called DPDCH (Dedicated Physical Data Channel), and a control channel, called DPCCH (Dedicated Physical Control Channel). The control channel transmits in particular transmission, channel estimation and power control parameters. The data and the control information items are transmitted in the form of frames, each frame comprising 15 transmission intervals and each transmission interval being constituted of 2560 chips.
The data are spread by means of a spreading code CDPDCH and the control information items are spread by means of a spreading code CDPCCH. The codes CDPDCH and CDPCCH are orthogonal to separate the DPDCH and DPCCH channels. The WCDMA standard, described in particular in the ETSI document ETSI 3GP TS 25.213 v4.4.0 (2003-12), entitled “Spreading and modulation (FDD)”, 3rd Generation Partnership Project, Technical Specification Group Radio Access Network, Release 4, specifies that the code cDPCCH is constituted of a sequence of bits equal to 1 and the code cDPDCH is constituted of pairs of identical bits, alternatively equal to 1 and to −1.
One assumes in
The spread data are then multiplexed on the I and Q channels (multiplication by j in 225 on the DPDCH channel and summation in 230) and the complex signal I+jQ thereby obtained is multiplied in 240 by a complex scrambling code, C, defined by:
Where the components C1 and C2 are constructed from a Gold sequence Zn:
C
1(k)=Zn(k) (2-1)
C
2(k)=Zn(k+16777232) mod. (225−1) (2-2)
the Gold sequence Zn being itself obtained with the aid of two sequences of maximal length, noted xn and y
Z
n=2zn(k)−1 (3-1)
z
n(k)=xn(k)+y(k) (3-2)
In the expressions (2-1), (2-2), (3-1) and (3-2), the symbols in upper case (C1,C2,Zn) represent BPSK values {−1, +1} and the symbols in lower case (c1,c2,zn,xn,y) their binary equivalents {0, 1}. Moreover, the addition in (3-2) is binary.
It will be recalled that a sequence of maximal length, or M-sequence, is obtained from a primitive polynomial. If the degree of said polynomial is m the period of the sequence is maximal, i.e. 2m−1. In practice, an M-sequence is generated by means of a shift register (LFSR) with m stages, looped back on itself, the taps of the register corresponding to the coefficients of the generator polynomial. The M-sequences xn and y are respectively generated by means of generator polynomials g(x)=x25+x22+1 and h(x)=x25+x24+x23+x22+1, in other words, by recurrence relations:
x
n(k+25)=xn(k+3)+xn(k) (4-1)
y(k+25)=y(k+3)+y(k+2)+y(k+1)+y(k) (4-2)
The M-sequences xn and y are reinitialised at each start of frame, in other words every 38400 chips. The sequence y is initialised by placing all of the bits of the register at 1 (y(0)=y(1)= . . . y(24)=1), i.e. by the word SRy=225−1. The sequence xn is for its part initialised by a word of 25 bits, SRx
We will place ourselves hereafter in the scenario represented in
We will distinguish two embodiments depending on whether the base station 120 is synchronised beforehand or not on the signal transmitted by the terminal 130, in other words depending on whether the base station 120 has identified the start of frame.
For the sake of simplification but without prejudice to generalisation, we will assume hereafter that the channel between the terminal 130 and the base station 120 is AWGN. If the channel has multiple paths, the latter generate an additional interference that will be taken into account in the noise term.
The signal received by the base station 120 is of the following form:
r(k)=eiθC(k)(βdxDPDCH(k)+jβcxDPCCH(k))+n(k) (5)
where θ is the phase shift introduced by the channel, βd/βc are real coefficients that are a function of the gain on the DPCCH and DPDCH channels, xDPDCH(k) and xDPCCH(k) are respectively the data and control signals after spreading (by the spreading codes CDPDCH and cDPCCH in 210 and 220 respectively), n(k) is a noise sample assumed additive, white, Gaussian, centred (AWGN), C(k) is the chip of the scrambling code generated at the instant kTc where Tc is the chip period.
The present invention uses a differential processing of the signal received. Said signal, optionally filtered by means of a suitable filtering at the channel, is sampled at the chip frequency 1/Tc. The differential treatment consists in carrying out the Hermitian product of two successive samples, i.e.:
Given the spreading codes used for the DPDCH and DPCCH channels, xDPDCH(2k+1)xDPDCH(2k)=1 and xDPCCH(2k+1)xDPCCH(2k)=1. The successive chips of the scrambling code satisfy the relation:
C(2k+1)C(2k)*=−2jC1(2k+1)C1(2k)C2(2k) (7)
The differential value u(2k) obtained at the instant 2kTc (taking for origin the start of the frame) may be expressed in the following form:
u(2k)=−2j(βc2+βd2)C1(2k+1)C1(2k)C2(2k)+b(2k) (8)
where one has grouped together in b(2k) the three noise terms. If one denotes v(k)=−lm(u(2k)), v(k) is a real value representing, under a signed form (BPSK), the bits of the sequence a defined by:
with
A(k)=C1(2k+1)C1(2k)C2(2k) (9-2)
In other words, if v(k) is positive, â(k)=1 and, if v(k) is negative, a(k)=0, where á(k) is the estimation of a(k).
From the definition of C1 and C2, cf. expressions (2-1), (2-2), (3-1) and (3-2), it may be shown that a(k)={tilde over (x)}n(k)+{tilde over (y)}(k) with:
{tilde over (x)}
n(k)=xn(2k)+xn(2k+1)+xn(2k+4)+xn(2k+7)+xn(2k+18) (10-1)
{tilde over (y)}(k)=y(2k)+y(2k+1)+y(2k+4)+y(2k+6)+y(2k+17) (10-2)
It can be shown that the decimation of an M-sequence by a power of 2 (here simply by a factor 2) is none other than a shifted version of said M-sequence. In the same way, the sum of two shifted versions of an M-sequence again leads to a shifted version of said M-sequence. Thus, the M-sequence {tilde over (x)}n has the same generator polynomial as xn, only the content of the shift register during the initialisation at start of frame being different. In a similar manner, the M-sequence {tilde over (y)} has the same generator polynomial as y, only the content of the shift register during the initialisation at start of frame being different.
If one now assumes that the receiver of the base station 120 is synchronised on the start of frame, it is possible to generate the sequence y(k) because one then knows the initial state SRy (SRy=225−1) of the shift register of y(k) at the start of frame. One may deduce therefrom the sequence y(k) from the expression (10-2).
If one multiplies v(k) by {tilde over (Y)}(k)=2{tilde over (y)}(k)−1, one obtains the sequence of observables:
ε(k)=v(k){tilde over (Y)}(k)=2(βc2+βd2){tilde over (X)}(k)+w(k) (11)
where {tilde over (X)}n(k)=2{tilde over (x)}n(k)−1 and w(k) is a noise term, which has the same statistical properties as b(k).
As explained later, it is possible to decode {tilde over (x)}n(k) from the observation of ε(k). One may then determine the content of the register SR{tilde over (x)} of the generator of the sequence {tilde over (x)}n at the start of the frame and finally deducing therefrom the content of the register SRx of the generator of the sequence xn
In this first embodiment, we will assume that the receiver of the base station 120 is synchronised with respect to the signal transmitted by the terminal 130. According to this first embodiment, the receiver has either effectively identified beforehand the start of a frame, or made the assumption that a given sample corresponded to a start of frame. In the second case, the receiver could test in turn a series of samples and determine, with the aid of a step 360 described later, whether the assumption of synchronisation was well satisfied.
At step 310, one samples the signal received at the chip frequency of the scrambling code, 1/Tc, if need be after a filtering matched to the transmission channel between the terminal 130 and the base station 120.
The samples r(k) thus obtained are subject to a differential processing in 320. More precisely, for each sample, one calculates the Hermitian product of said sample with the preceding sample. One then determines the imaginary part v(k)=−Im(u(2k)) of the products u(k) of even rank to obtain a sequence of imaginary parts v(k), called differential values.
At step 330, one multiplies the elements of the sequence of differential values with the elements of the M-sequence {tilde over (y)} obtained as shifted version of the M-sequence y serving to form the Gold sequence zn of the scrambling code. One thereby obtains a sequence of observables ε(k), as expressed in (11).
At step 340, one performs an iterative decoding of the observables ε(k) from the preceding step to obtain an estimation of the sequence {tilde over (x)}n. Given that the sequence of bits {tilde over (x)}n(k) is an M-sequence obtained by a generator polynomial, in this case g(x), it may be decoded by a belief propagation algorithm (belief propagation decoding) as described for example in the article of K. M. Chugg and M. Zhu entitled “A New Approach to Rapid PN Code Acquisition Using Iterative Message Passing Techniques”, IEEE Journal on Selected Areas in Communications, vol. 25, no. 5, May 2005. In fact, the generator of an M-sequence of generator polynomial:
g(x)=g0+g1x+ . . . +grxr (12)
may be seen as a parity matrix encoder of size (M−r)×M:
where M is the number of successive bits considered at the output of the generator. This parity matrix reflects the constraints between the bits of the M-sequence. The generator of the M-sequence may be represented, following the example of LDPC encoders, by a series of variable nodes and a series of constraint nodes. The decoding then takes place in an iterative manner, by passing messages between the nodes of variables and the nodes of constraints.
In the present case, the observables are the values ε(k). The algorithm makes it possible to estimate at each iteration the soft values (for example the log likelihood ratios or LLRs) of the bits {tilde over (x)}n(k). The bits {tilde over (x)}n(k) are then obtained through a hard decision on these LLRs.
At step 350, one deduces from the preceding step the content SRx of the shift register at start of frame for the sequence xn. This content defines in an univocal manner the sequence xn, thus the Gold code zn=xn+y and consequently the components C1,C2 of the scrambling code C from the relations (2-1), (2-2), (3-1) and (3-2). The scrambling code estimated at step 350 is noted Ĉ, its estimated components are noted Ĉ1,Ĉ2.
At step 410, one determines the content of the shift register, at start of frame, of the generator of the M-sequence {tilde over (x)}n, in the Fibonacci representation. Given the connection between the stages of the register, the content of the shift register is the word formed by the first values {tilde over (x)}n(k), k=0, . . . , 24.
From the content of said shift register, one determines in 420 the content of the shift register of the generator of the non-decimated M-sequence.
It will be recalled that:
{tilde over (x)}
n(k)=x′n(2k) (14-1)
where x′n represents the non-decimated M-sequence that satisfies:
x′
n(k)=xn(k)+xn(k+1)+xn(k+4)+xn(k+7)+xn(k+18) (14-2)
As we have noted above, the sequence {tilde over (x)}n is of same generator polynomial as the original sequence xn. In fact the sequence x′n obtained as sum of shifted versions of the M-sequence xn is an M-sequence of same generator polynomial as xn, and {tilde over (x)}n obtained by decimation of a factor 2 of the sequence x′n is again an M-sequence of same generator polynomial as x′n and thus as xn.
The content of the shift register of the decimated sequence {tilde over (x)}n may be obtained in a Fibonacci representation of the generator as illustrated in
More precisely, if one notes SRFibx′ the vector of size r=25 giving the content of the shift register in the Fibonacci representation of the generator of the sequence x′n, and SRFib{tilde over (x)} the content of the shift register for the decimated sequence {tilde over (x)}n one has:
SR
Fib
x′
=T
undecim
1/2
SR
Fib
{tilde over (x)} (15)
where Tundecim1/2 is a matrix of size r×r giving the change of state between the decimated sequence {tilde over (x)}n and the original sequence x′n for a decimation of factor ½.
The matrix tundcim1/2 may be obtained according to the method detailed in the article cited above. To do this, one calculates firstly α−1, the root of the inverse polynomial of the generator polynomial (g−1(x)=g(x)x−r=x25+x3+1) of the non-decimated sequence, Tundecim1/2 is then the binary matrix of which the ith line is given by the decomposition coefficients, aik:
where p is an integer satisfying the relation of congruence 2p≡1 mod(2r−1), for example p=2r−1.
It may be shown that the following relations are satisfied, respectively, for the even lines and the odd lines:
a
−2ip=α−i (17-1)
α−(2i+1)p=α−p−1 (17-2)
The even lines of the matrix tundecim1/2 are obtained directly from (16) and (17-1). For the odd lines, one calculates the remainder of the polynomial division of α−p−i by the inverse polynomial g−1, i.e.:
The odd line 2i+1 then being given by the coefficients ci,k by virtue of (16), (17-2) and (18).
One thereby obtains the content SRFibx′ of the shift register for the non-decimated sequence, at start of frame.
One then deduces therefrom, at step 430, the content SRFibx of the shift register for the sequence xn. If one notes F the state transition matrix of the generator of the sequence xn in the Fibonacci representation, in other words, the matrix giving the following state, SRFibx(k+1) (that is the content of the shift register at the instant (k+1)Tc) as a function of the current state, SRFibx(k), i.e.:
SR
Fib
x(k+1)=F.SRFibx(k) (19)
with:
The expression (14-2) is then translated into matrix form:
SR
Fib
x′=(F18+F7+F4+F+I)SRFibx (21)
where the time index k has been omitted for the sake of simplicity.
In the end, the content SRFibx of the shift register for the sequence xn is obtained by:
SR
Fib
x=(F18+F7+F4+F+I)−1SRFibx′=ΩTundecim1/2SRFib{tilde over (x)} (22)
with: Ω=(F18+F7+F4+F+I)−1 matrix that may be calculated once and for all and stored in a memory of the receiver.
If need be, an error control may be carried out at this stage. In fact, according to the standard, the most significant bit (MSB) in the shift register must be equal to 1 at start of frame. If said bit is not equal to 1, the estimation of the scrambling code C is then interrupted.
The content SRFibx of the shift register of the sequence xn at start of frame makes it possible to determine the elements xn(k) of the sequence. One deduces therefrom at step 440 the bits zn(k)=xn(k)+y(k) of the Gold sequence then the components Ĉ1(k), Ĉ2(k) by means of the relations (2-1), (2-2) and finally the elements of the scrambling code Ĉ(k) by the expression (1).
Returning to
It will be recalled that at step 320, one obtains the differential values, cf. expression (8):
v(k)=2(βc2+βd2)C1(2k+1)C1(2k)C2(2k)+b1(2k) (23)
where b1(2k) is a noise sample. The values v(k) are called observed differential values.
Once the content SRFibx of the shift register of the sequence xn obtained, and the scrambling code Ĉ deduced at step 350, one may calculate the sequence {circumflex over (μ)} defined by:
û(k)=Ĉ1(2k+1)Ĉ1(2k)Ĉ2(2k) (24)
The values {circumflex over (μ)}(k) are called calculated differential values.
One then performs the correlation between the sequence v of the differential values with the sequence {circumflex over (μ)} of the calculated differential values, i.e.:
the correlation being taken each time on a sequence of L samples.
On compares the result of the correlation V to a predetermined threshold, λ.
if V>λ one concludes therefrom that the receiver is well synchronised with the scrambling code. Failing this, the receiver is not synchronised with the scrambling code.
In this second embodiment, the receiver is not synchronised on the signal of the transmitter 130 and consequently does not know the start of the frames. It is thus incapable a priori of directly generating the M-sequence y and a fortiori the shifted sequence {tilde over (y)}.
The steps 610 and 620 are identical to the steps 310 and 320 described previously.
At the output of the differential processing in 620, one has differential values:
v(k)=2(βc2+βd2)A(k)+b1(2k) (26)
where A(k)=C1(2k+1)C1(2k)C2(2k) (cf. expression 9-2) is a signed representation of a(k)={tilde over (x)}n(k)+{tilde over (y)}(k) and {tilde over (x)}n(k),{tilde over (y)}(k) are respectively defined by the expressions (10-1) and (10-2).
It may be shown that the sum sequence a is generated by the generator polynomial ga(x) equal to the product of the generator polynomials of the sequences {tilde over (x)} and {tilde over (y)}:
g
a(x)=g(x)h(x) (27)
At step 630, one performs an iterative decoding of the observables v(k) to obtain an estimation of the sequence a. As at step 340, said decoding may be performed by a belief propagation algorithm. The decoding takes place, in a known manner per se, by passing messages between the nodes of variables and the nodes of constraints, the variables being observables v(k) and the constraints being set by the generator polynomial ga(x).
One obtains at the end of the decoding a sequence of estimated bits.
The polynomial ga(x) being of degree 50, one may determine at each instant the content SRaFiba of the register of the sequence a, in the Fibonacci representation (cf.
The content SRGala of the register of the sequence a in the Galois representation is determined at step 640.
Generally speaking, if one notes SRFib the content of the shift register of a sequence in the Fibonacci representation and SRGal the content of the shift register of this same sequence in the Galois representation and if one notes TGF the matrix of transposition of states from the Fibonacci representation to that of Galois, one has:
SR
Gal
=T
GF
SR
Fib (28)
where the elements of the transposition matrix are given by taking the notation conventions of
T
ij
GF
=g(i−j) if j≦i and TijGF=0 if not (29)
In the present case, SRGala=Tg
At step 650, one deduces from the state SRGala of the register of the sequence a, the respective states of the registers of sequences {tilde over (x)}n and {tilde over (y)} in the Galois representation.
If one notes in the polynomial form
the state of the register of the sequence a,
the state of the register of the sequence {tilde over (x)}n and
the state of the register of the sequence {tilde over (y)} in the Galois representation (cf.
A
reg(x)=g(x){tilde over (Y)}reg(x)+h(x){tilde over (X)}reg(x) (30)
This relation can again be expressed, in an equivalent manner, in a matrix form:
where:
SRGala=(aGal(0), . . . , aGal(49))T, SRGal{tilde over (x)}=({tilde over (x)}Gal(0), . . . , {tilde over (x)}Gal(24))T, SRGal{tilde over (y)}=({tilde over (y)}Gal(0), . . . , {tilde over (y)}Gal(24))T are respectively the vectors giving the states of the registers of the sequences a, {tilde over (x)} and {tilde over (x)}n at a given instant in the Galois representation and:
One may then deduce the states of the registers SRGl{tilde over (x)} and SRGal{tilde over (y)} in the Galois representation by:
At step 660, one determines the content of the shift registers of the sequences {tilde over (y)} and {tilde over (x)}n in the Fibonacci representation, noted SRFib{tilde over (y)} and SRFib{tilde over (x)}.
The state of the register in the Fibonacci representation may in fact be from the state of the register in the Galois representation by means of the matrix TGF defined previously:
SR
Fib=(TGF)−1SRGal (34)
One may thus determine the state of the registers SRFib{tilde over (y)} and SRFib{tilde over (x)} in the following manner:
SR
Fib
{tilde over (y)}=(ThGF)−1SRGal{tilde over (y)} (35-1)
SR
Fib
{tilde over (x)}=(T
g
GF)−1SRGal{tilde over (x)} (35-2)
where ThGF and TgGF are the transposition matrices according to (33) for the polynomials h(x) and g(x) respectively.
At step 670, one determines the respective contents of the shift registers of the sequences y and xn from those of the sequences {tilde over (y)} and {tilde over (x)}n.
To do this, one proceeds as at step 420, except that one also estimates the content of the register of the sequence y, unknown here from the receiver, i.e.:
SR
Fib
x=ΩgTundecim1/2SRFib{tilde over (x)} (36-1)
SR
Fib
y=ΩhSRFib{tilde over (y)} (36-2)
where one has distinguished here the matrices Ωg,Ωh et Tundecim,g1/2 to recall that they depend on the coefficients of the generator polynomials g(x) and h(x) respectively. From the states SRFibx and SRFiby at a measuring instant k0Tc one may determine the bits xn(k) and y(k) at an instant kTc.
At step 680, one determines the scrambling code Ĉ, in other words the values Ĉ(k) from the bits xn(k) and y(k) obtained at the preceding step, by means of the relations (2-1), (2-2), (3-1), (3-2).
One may moreover synchronise the receiver on the start of the frame given that one knows the state of the register of the sequence y at start of frame (initial state) and that at the instant of measure k0Tc. One applies as many times as necessary the change of state matrix (of the generator of the sequence y) to the initial content up to one finding SRFiby (obtained at the instant of the measure). If m is the number of successive applications of the change of state matrix to obtain SRFiby, the shift of the measuring instant with respect to the start of the frame is none other than mTc.
Knowing the scrambling code of the terminal 130 and its spreading code, the receiver of the base station 120 can estimate the symbols transmitted by the terminal. It can then regenerate the contribution to the signal received from said terminal, from the scrambling code, the spreading code, the shaping filter and from the impulse response of the channel. This contribution is then subtracted from the signal received, in a known manner per se, to eliminate the interference due to the terminal 130. If need be, this operation may be repeated in parallel or in series to eliminate the interference of several users of the WCDMA macro-cellular system.
Number | Date | Country | Kind |
---|---|---|---|
12 52338 | Mar 2012 | FR | national |