Method for decoding 2X2 spatiotemporal codes, in particular Golden type code

Information

  • Patent Grant
  • 8194763
  • Patent Number
    8,194,763
  • Date Filed
    Friday, May 11, 2007
    17 years ago
  • Date Issued
    Tuesday, June 5, 2012
    12 years ago
Abstract
A method is provided for decoding spatiotemporal codes, in particular Golden type code. The received vector is subjected to a MMSE-GDFE filtering, a constellation re-centering to define a Z-matrix, a permutation to obtain X-shaped matrices, a trellis base reduction and a ZF-DFE algorithm by processing the elements of the Z-matrix layer by layer. Each layer includes both elements of the diagonal or anti-diagonal of the Z-matrix.
Description
CROSS REFERENCE

The present application claims priority to PCT/FR2007/000798 filed May 11, 2007.


FIELD OF THE INVENTION

The present invention relates to a method for decoding 2×2 space-time codes of a vector Y, in particular of the Golden Code type. The present invention can also be applied to 2×2 space-time codes meeting the following conditions:

    • the code has a structure in two layers,
    • each layer representing the canonical embedding of a principal ideal of the ring of integers αZ[i,θ] of a number field Q[i,θ] of degree 2 with respect to Q[i],
    • the canonical embedding matrix being proportional to a unitary matrix.


BACKGROUND

In a general manner, in a wireless communication system, using electromagnetic waves as the physical transmission medium, multiple reflections (multiple paths) due to the different obstacles in the propagation space (propagation in the urban environment or in the “indoor” environment) induce phenomena of fading of the signal, i.e. that over a complete frequency range, it is possible to observe destructive interference. The relative movement of the environment with respect to the transmitter and to the receiver makes these fading phenomena stochastic. These fading channels considerably penalise the performance of conventional digital communication systems. To combat fading phenomena effectively, it is necessary that the receiver has available several replicas containing the information transmitted, replicas which have suffered mutual independent fading. The concept of diversity refers to the creation of these replicas and the order of diversity is defined as the number of “independent” replicas which the receiver has available. To mention some examples of diversity: time diversity (the information is repeated with a time difference greater than the coherence interval in order that there is decorrelation between the replicas), frequency diversity, path diversity in CDMA systems, receive antenna diversity. Since 1996, a new coding method, named Space-time coding, using several transmit and receive antennas, has allowed the use of a new form of diversity: transmit antenna diversity. Space-time coding is not the only technique resorting to several transmit and receive antennas: these techniques are combined under the name MIMO (Multiple Input Multiple Output). Recourse to Space-time coding over several antennas considerably improves the performance (owing to diversity) and information rate (owing to multiplexing) of telecommunications systems in an environment having fading (“fading channel”).


From all coherent Space-time codes (i.e. that the receiver has perfect knowledge or at least an estimate of the channel coefficients) using two transmit antennas known at the present time, the one offering the best performance is the Golden Code as described in the document: J. C. Belfiore, G. Rekaya and E. Viterbo, “The Golden Code: A 2×2 Full-Rate Space-Time Code with Non-Vanishing Determinants,” IEEE Trans. Inform. Theory (April 2005). The Golden Code is actually a maximum diversity (the transmit diversity is 2) and maximum multiplexing (2 symbols per channel use). Furthermore, it also has the highest coding gains (whatever the constellation used). In addition, it was demonstrated recently that the Golden Code can be used on an “Amplify and Forward Relay Channel” with a relay and an antenna and that it can benefit from diversity of collaboration.


The Golden Code only has excellent performance for Maximum Likelihood decoding. As for a number of space-time codes (linear codes), the Maximum Likelihood decoding of the Golden Code is reduced to the search within a region (the shaping region) of a lattice (of dimension 8 for the Golden Code), a lattice which changes according to the channel coefficients, from the point closest to the point received. In order to do this, algorithms to search for the closest point within a lattice were adapted to the decoding of Space-time codes: the Sphere Decoder and the Schnorr-Euchner enumeration. These algorithms need a highly variable number of iterations and are therefore suited only with difficulty to a hardware implementation operating in real time. Accelerations of these algorithms using pre-processing, in particular basis reductions of the LLL type, have also been studied already.


Given the complexity of decoding at Maximum Likelihood decoding, sub-optimal algorithms for decoding Space-time codes have been developed. Some of these algorithms stem from interference equalization and cancellation: this is the case with the ZF (Zero Forcing), MMSE (Minimum Mean Square Error) and ZF-DFE (Decision Feedback Equalizer) algorithms described in: J. Foschini, G. Golden, R. Valenzuela and P. Wolniansky, “Simplified processing for high spectral efficiency wireless communication employing multi-element arrays”, IEEE Journal on Selected Areas Communications, vol. 17, p 1841-1852, November 1999, the V-BLAST decoding algorithm. However, these decoders cannot benefit either from transmit diversity or receive diversity.


Recently, low complexity sub-optimal algorithms have been proposed. They use MMSE or ZF algorithms combined with an LLL basis reduction. Thanks to LLL, these algorithms can use the diversity in its entirety, which is not the case in the absence of this pre-processing. In the document: A. D. Murugan, H. El Gamal, M. O. Damen and G. Caire, “A Unified Framework for Tree Search Decoding: Rediscovering the Sequential Decoder”, IEEE Transactions on Information Theory, vol. 52, no. 5, May 2006, proved the interest in using MMSE-GDFE filtering as pre-processing in order be able to perform a decoding in the lattice without considering the “shaping” constraint and to make use reduction algorithms such as LLL. Moreover, a general formalising of searching within a tree was proposed, capable accordingly of describing all the techniques resulting from the decoding within a lattice and introducing sequential decoding techniques.


However, even this latter technique cannot optimise the advantages of the Golden Code.


SUMMARY

A purpose of the present invention is to propose a new decoder benefiting from the diversity of a Golden Code. Another purpose of the invention is to design a real time space-time decoder.


At least one of the aforementioned objectives is achieved with a method for decoding 2×2 space-time codes of a vector Y, in particular of the Golden Code type, characterized in that it comprises the following steps:

    • a filtering of the MMSE-GDFE type is carried out in order to obtain a vector YF=RX+W, where YF is the vector Y filtered by means of a filter matrix F (“forward filter”), R a conventional matrix named “backward filter”, X the vector transmitted and W the complex noise matrix,
    • a constellation recentring is carried out so that the vector to be determined becomes Z, such that Z=YF−2KMRΓS0=2KMRΓS+W, KM being the normalization constant for the constellation in question, Γ being the Golden Code, and S the vector for the information symbols,
    • a step of permutation of the elements of the matrices Z, R and Γ is carried out in order to obtain {tilde over (Z)}, {tilde over (R)} and {tilde over (Γ)} so that {tilde over (R)}HR is a matrix in the form of an X and the complex number “i” is moved from Γ to R, and
    • a step of lattice basis reduction is carried out so that {tilde over (Z)}=2KM{tilde over (ψ)}{tilde over (Γ)}S′+W with {tilde over (ψ)}={tilde over (R)}.Δα(x1,x2,x3,x4) and S′=πα−1(x1,x2,x3,x4).S, πα(x1,x2,x3,x4) being a basis change matrix, πα(x1,x2,x3,x4) is the matrix associated with Δα(x1, x2, x3, x4) which is a matrix in which the determinant module is equal to 1 and defined such that ΔαHΔα is a matrix in the form of an X,
    • the ZF-DFE decoding algorithm is applied, in which among the four elements of {tilde over (Z)} two layers are identified, each layer comprising the two elements of the diagonal or anti-diagonal of {tilde over (Z)}; the DFE algorithm is applied layer by layer and the ZF algorithm within each of the layers.





DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS

Further aspects of the present invention will become apparent from the following description which is given by way of example only and with reference to the accompanying drawings in which:



FIG. 1 is a performance curve for a decoder according to the invention compared with a decoder of the prior art and a Maximum Likelihood decoder; and



FIG. 2 is a flow chart of steps according to the invention.





DETAILED DESCRIPTION

The decoding algorithms of the prior art having performances comparable to Maximum Likelihood process the Golden Code decoding as that of any lattice of dimension 8. They do not consider two specific aspects of its structure: its construction in 2 layers and the algebraic structure of each of these two layers. The present invention proposes to carry out a layer by layer decoding (as in the method of a DFE), reducing the problem to one of dimension 2. The decoding within each layer is carried out by a simple ZF technique after an algebraic reduction. Such a technique of decoding by layers has the advantage of handling at each step 2×2 diagonal, or known in advance, matrices. In order to obtain performances close to Maximum Likelihood, a reduction capable of combining the two layers before decoding them one by one is advantageously implemented. Conventional reduction techniques (LLL or Korkhine-Zolotareff, for example) destroy the layered structure. This is why a new form of reduction, christened algebraic reduction, can be used.


According to one advantageous characteristic of the invention, the permutation of {tilde over (Z)} is as follows:







Z
~

=

[




z

1
,
1







z

2
,
2







z

1
,
2







z

2
,
1





]






with the following convention






Z
=


[




z

1
,
1







z

2
,
1







z

1
,
2







z

2
,
2





]

.





In this permutation, the first layer is constituted by the first and last Z elements. The second layer is constituted by the second and third Z elements.


Advantageously, {tilde over (R)} is a matrix in X form such that:








R
~

=



[




r

1
,
1

1



0


0



i
·

r

1
,
2

1






0



r

2
,
2

2




r

2
,
1

2



0




0



r

1
,
2

2




r

1
,
1

2



0





r

2
,
1

1



0


0



i
·

r

2
,
2

1





]






and






Γ
~


=


1

5




[



α



α





θ



0


0





α
_





α
_







θ
_




0


0




0


0


α


αθ




0


0



α
_





α
_







θ
_





]




,





α and θ being the Golden Code coefficients such that:







θ
=


1
+

5


2


,


θ
_

=


1
-

5


2


,





α=1+i−i.θ, α=1+i−i.{tilde over (θ)}


Preferably:








Δ
α



(


x
1

,

x
2

,

x
3

,

x
4


)


=

[




x
1



0


0




α

α
_




x
4






0




x
_

1






α
_

α




x
_

4




0




0




α

α
_





x
_

2






x
_

3



0







α
_

α



x
2




0


0



x
3




]






and







Π
α



(


x
1

,

x
2

,

x
3

,

x
4


)


=

[




x
1
1




x
2
1




x
1
4





x
1
4

-

x
2
4







x
2
1





x
1
1

+

x
2
1





x
2
4




-

x
1
4








x
1
2

+

x
2
2






x
1
2

+

2
·

x
2
2







x
1
3

+

x
2
3





-

x
2
3







-

x
2
2






-

x
1
2


-

x
2
2





-

x
2
3





x
1
3




]





where ∀j 1≦j≦4 xj=x1j+θ.x2j (x1j et x2jεZ[i]).


According to one advantageous embodiment of the invention, Δα is determined such that during a QR decomposition, both elements of a single layer are substantially of the same value. This accordingly defines a first equilibrium criterion within each layer.


According to yet another advantageous embodiment of the invention, {tilde over (Z)} being defined as two layers, a first layer composed of elements on the diagonal and a second layer composed of elements on the anti-diagonal, Δα is determined such that, during a QR decomposition, the product of the two elements of the second layer is greater than the product of the two elements of the first layer. This accordingly defines a second criterion for maximizing the power of the second layer.


Moreover, during application of the ZF algorithm for the second layer, it is preferable to extract p possible candidates and then, during application of the ZF algorithm for the first layer, p possible candidates are also extracted and then the best candidate vector is determined on completion of the overall ZF-DFE algorithm. Advantageously, p is equal to 2.


The present invention is applied advantageously if {tilde over (R)} and Δα are X or diamond matrices.


Other advantages and characteristics of the invention will become apparent on examination of the detailed description of an embodiment which is in no way limitative, and the attached figures. FIG. 1 is a performance curve for a decoder according to the invention compared with a decoder of the prior art and a Maximum Likelihood decoder. FIG. 2 is a flow chart of steps according to the invention.


For the description which follows, we shall use the following notations and conventions:

    • All assemblies in bold
    • Z the ring of relative integers
    • Q the field of rational numbers
    • R the field of real numbers
      • i is the number defined by i2=−1
      • C the field of complex numbers
      • Q[i] the field defined by Q[i]={x+i.y with (x,y)εQ2}
      • Z[i] the ring defined by Z[i]={x+i.y with (x, y)εZ2} (ring of Gauss integers)
      • Q[θ] the algebraic extension field of Q generated by [θ]
      • Z[θ] the ring of algebraic integers from the number field Q[θ]
      • θ is an algebraic integer of degree 2
      • Q[i,θ] the algebraic extension field of Q[i] generated by θ. This is an algebraic extension of Q of degree 4.
      • Z[i,θ] the ring of algebraic integers of the body of numbers Q[i,θ]
      • custom character(x) the real part of a complex number x
      • custom character(x) the imaginary part of a complex number x
      • x* is the complex conjugate of x
      • GLn(E) all invertible square matrices of dimension n with coefficients in E (where E is a ring) and in which the inverse is also with coefficients in E
      • In the identity matrix of dimension n
      • XT the transposed matrix of the X matrix
      • XH the conjugated transposed matrix of the X matrix
      • └x┐ the largest integer less than or equal to x
      • In (x) the Napierian logarithm of x for x>0
    • E(.) the expected value.


The principle of the Golden Code will now be described.


For a constellation M2 QAM, the Golden Code (annotated ΓM) is the finished set of the 2×2 matrices with complex coefficients defined as follows:







Γ
M

=

{




1

5




[




α
·

(

a
+

b
·
θ


)





α
·

(

c
+

d
·
θ


)







i
·

α
_

·

(

c
+

d
·

θ
_



)






α
_

·

(

a
+

b
·

θ
_



)





]



with





a

,
b
,
c
,

d



M
2


QAM



}






Where






θ
=


1
+

5


2


,


θ
_

=


1
-

5


2


,

α
=

1
+
i
-

i
·
θ



,


α
_

=

1
+
i
-

i
·

θ
_









and







M
2


QAM

=

{



K
M



(


(


2
·
k

+
1
-
M

)

+

i
·

(


2
·
n

+
1
-
M

)



)


|


(

k
,
n

)




{

0
,





,

M
-
1


}

2



}






where






K
M

=


1



2
·

(


M
2

-
1

)


3








is





the





normalization





constant





of






M
2



QAM
.






In the MIMO context, the matrix notation is interpreted in the following manner: if a word X from the Golden Code (XεΓM) is transmitted, this means that:

    • x1,1 is sent by the antenna i=1 at time t=1.
    • x1,2 is sent by the antenna i=1 at time t=2.
    • x2,1 is sent by the antenna i=2 at time t=1.
    • x2,2 is sent by the antenna i=2 at time t=2.


By considering ΓM in R8 (or C4), the Golden Code can be seen as a portion of a lattice of dimension 8 (or of complex dimension 4) decentred and delineated by a shaping region. To do this, it suffices to rewrite ΓM in the following manner:







Γ
M

=

{







2
·

K
M



5




[




α
·

(


s
1

+


s
2

·
θ


)





α
·

(


s
3

+


s
4

·
θ


)







i
·

α
_

·

(


s
3

+


s
4

·

θ
_



)






α
_

·

(


s
1

+


s
2

·

θ
_



)





]


+









K
M

·

(

1
+
i

)

·

(

1
-
M

)



5




[




α
·

(

1
+
θ

)





α
·

(

1
+
θ

)







i
·


α
_



(

1
+

θ
_


)







α
_

·

(

1
+

θ
_


)





]








avec


(


s
1

,

s
2

,

s
3

,

s
4


)






Z


[
i
]


4



Q
M
4






}





where QM=[0;M−1]+i.[0;M−1]


Subsequently, the information symbols vector is annotated S=(s1, s2, s3, s4)T. It is clear that the determination of the word of the Golden Code is equivalent to the determination of the vector S of Z[1]4 in the shaping region QM4.


Advantageously, a Golden Code word consists of two layers:

    • the pair (x1,1, x2,2) forms the layer 1, which depends only on the pair (s1, s2)
    • the pair (x1,2, x2,1) forms the layer 2, which depends only on the pair (s3, s4);


We repeat below the “idealistic” decoding criterion at Maximum Likelihood


Let us consider the case of a receiver having N receive antennas (N≧2). In the case of a MIMO Flat Fading channel (which is optionally different between time 1 and time 2), if we suppose that Golden Code word X was transmitted, the signals yj,t received by the receive antenna j (1≦j≦N) at time t (1≦t≦2) can be written in the form:

yj,t=hj,1t.x1,t+hj,2tx2,t+bj,t  (Equation 1)


where hj,it designates the channel coefficient between the transmit antenna i and the receive antenna j at time t and bj,t the complex noise on the receive antenna j at time t. The complex noise is assumed to be symmetric circularly centred Gaussian of variance N0 (the real and imaginary parts have for variance N0/2) and independent according to space (according to j) and the time (according to t), i.e.:

E(bj,tbj′,t′*)=N0δt,t′δj,j′


where δt,t′ designates the Kronecker symbol between t and t′.


The channel coefficients and the noise variance are assumed to be known by the receiver.


Equation (1) can be rewritten as a matrix:








[




y

1
,
1












y

N
,
1







y

1
,
2












y

N
,
2





]



Y


=




[




h

1
,
1

1




h

1
,
2

1



0


0



















h

N
,
1

1




h

N
,
2

1



0


0




0


0



h

1
,
1

2




h

1
,
2

2



















0


0



h

N
,
1

2




h

N
,
2

2




]



H


·

[




x

1
,
1







x

2
,
1







x

1
,
2







x

2
,
2





]


+


[




b

1
,
1












b

N
,
1







b

1
,
2












b

N
,
2





]



B







Now, given that XεΓM, there is SεZ[i]4∩QM4 such that:







[




x

1
,
1







x

2
,
1







x

1
,
2







x

2
,
2





]

=


2
·

K
M







1

5




[



α



α





θ



0


0




0


0



i






α
_





i






α
_







θ
_






0


0


α



α





θ






α
_






α
_







θ
_









0


0



]




Γ


·

(

S
+

S
0


)










with






S
0


=




(

1
+
i

)

·

(

1
-
M

)


2



[



1




1




1




1



]






Therefore, we have:

Y=2.KM.H.Γ.(S+S0)+B


From which:

Y′=Y−2.KM.H.Γ.S0=2.KMH.Γ.S+B


It is easy to demonstrate that the Maximum Likelihood decoding consists of deciding, knowing Y′ and the channel coefficients, that the vector transmitted is the vector Ŝ defined by:







S
^

=

Arg


(


Min

S




Z


[
i
]


4



Q
M
4











Y








-



·
S




2


)






with custom character=2.KM.H.Γ


Decoding at Maximum Likelihood consists of finding the point of the lattice of real dimension 8 (complex dimension 4), generated by custom character columns, closest to Y′, provided that the coordinates of this point belong to the shaping region (QM4). Provided that the custom character matrix is of real rank 8 (or complex rank 4), a decoding at Maximum Likelihood is feasible by the Sphere Decoder algorithm or by the Schnorr-Euchner enumeration algorithm, both duly modified to integrate the “shaping” constraint.


According to the present invention, the first step is the application of a MMSE-GDFE filter, 201 on FIG. 2.


The MMSE-GDFE filtering technique is a pre-processing technique used currently in the Space-Time code decoding field. It has been shown that MMSE-GDFE filtering can overcome the shaping constraint, without degrading performance significantly. Moreover, this filtering can guarantee that the virtual channel matrix is of full rank. By transforming the decoding problem into that of a search within a lattice for the point closest to a point received, the MMSE-GDFE filtering can benefit from lattice basis reduction techniques.


Given that the Golden Code matrix Γ is a unitary matrix, the MMSE-GDFE filtering matrix can be determined exclusively from H and N0 (both assumed to be known by the receiver).


The MMSE-GDFE filter matrix, annotated F (“forward filter”), of the matrix H is the 4×2.N complex matrix defined by:


F=(RH)−1HH, R is the backward filter,


where








(

R
H

)


-
1


=

[





(

R
1
H

)


-
1




0




0




(

R
2
H

)


-
1





]






with R1 (or R2) a triangular complex matrix greater than 2×2 (in which the diagonal terms are positive real numbers) obtained by the Cholesky decomposition of H1HH1+N0I2 (resp. H2HH2+N0I2).


In general, decoding in a lattice after MMSE-GDFE filtering is defined in the following manner.


The received symbols vector Y is multiplied by the matrix F, in order to obtain a complex vector of dimension 4, annotated YF:

YF=F.Y


It is easy to demonstrate that we have:

YF=R.X+W


where W is a complex noise vector of dimension 4, in which each of the components is of variance N0. The components of W are still mutually decorrelated, but are no longer Gaussian.


Therefore, we have, 202 on FIG. 2:

Z=YF−2.KM.R.Γ.S0=2.KM.R.Γ.S+W=custom characterS+W  (Equation 2)


with custom character=2.KM.R.Γ


In this case, given Z and R, the decoding method consists of deciding that the vector transmitted is the vector Ŝ defined by:







S
^

=

Arg
(


Min

S




Z


[
i
]


4



Q
M
4









Z
-


Λ
F

·
S




2


)





This decoding method is not equivalent to that of Maximum Likelihood, but damages performance only slightly while guaranteeing the invertibility of the new generator matrix (custom character). Moreover, that it is not penalizing to disregard the shaping condition. The decoding method then consists of deciding that the vector transmitted is the vector Ŝ defined by:







S
^

=

Arg
(


Min

S



Z


[
i
]


4








Z
-


Λ
F

·
S




2


)





This therefore involves finding the point of the lattice generated by the columns of custom character closest to Z.


If the coordinates of Ŝ do not confirm the “shaping” condition, it is possible to decide to delete or to reduce Ŝ in the shaping region while saturating the coordinates of Ŝ which do not confirm the shaping condition.


According to the invention, the decoder uses a lattice basis reduction. The general principle of lattice basis reduction is defined in the following manner.


Let custom character be a square real matrix of dimension n and ZR a point on Rn. Suppose that we are searching for the point of the lattice generated by custom character closest to ZR, i.e. we are searching for ŜR in Zn such that:








S
^

R

=

Arg
(


Min


S
R



Z
n









Z
R

-


Λ
R

·

S
R





2


)





If π is a square matrix of dimension n with unimodular integer coefficients (πεGLn(Z)), then its inverse π−1 also has integer coefficients. The matrix π is called basis change matrix.


We therefore have:

ZRcustom character.SR=ZRcustom character.π.π−1.SR=ZRcustom character′.SR


with custom character′=custom character.π and SR′=π−1.SR


Therefore the search for ŜR is equivalent to the search for Ŝ′R defined by:








S
^

R


=

Arg
(


Min


S
R




Z
n









Z
R

-



R




·

S
R







2


)





ŜR is obtained from the relationship: ŜR=π.ŜR


The objective of the basis reduction is obtained from a custom characterR an equivalent generator matrix custom characterR′ (which generates the same lattice), which has improved vector orthogonality and length properties in order to facilitate the search for the closest point.


There are different reduction criteria, with which algorithms are associated in order to carry out these reductions. The two principal reduction algorithms are: the LLL algorithm and the KZ algorithm. The LLL algorithm is the more frequently used as it is less complex than the KZ algorithm.


The algorithms for classifying the columns of the matrix are also reduction algorithms.


After MMSE-GDFE filtering, the basis reduction can be used to accelerate the optimal search algorithms such as the Sphere Decoder or the Schnorr-Euchner enumeration. Similarly, all the sub-optimal search algorithms in a tree can be improved using a basis reduction technique.


The general principle of a ZF decoding after MMSE-GDFE filtering and basis reduction is as follows.


After MMSE-GDFE filtering, we have (cf. Equation 2):

Z=custom character.S+W


In order to be able to use a reduction technique, it is necessary to work on real matrices and vectors. The conversion of a complex vector (resp. a complex matrix) into a real vector (resp. into a real matrix) is carried out in the following manner:







Z
R

=



[








]






and






Λ
R
F


=

[





-









(

Λ
F

)





]






In the case of the Golden Code, ZR is a vector of dimension 8 and custom character an 8×8 matrix.


We then have:

ZR=custom character.SR+WR


After reduction of the generator matrix custom character, the reduced matrix is annotated custom character and the basis change matrix π.


We then have:

ZR=custom characterSR′+WR  (Equation 3)


The decoded word is defined by ŜR=π.ŜR′ where ŜR′ is obtained by rounding the coordinates of (custom character)−1ZR. The term ZF (Zero Forcing) originates from the fact that we multiply the received word ZR by the inverse of the matrix custom character.


The general principle of a ZF-DFE decoding after MMSE-GDFE filtering and basis reduction is as follows.


The ZF-DFE decoding after basis reduction proceeds like ZF decoding up to equation 3. A QR decomposition (or Gram-Shmit orthogonalisation) of the matrix custom character is carried out:

custom character=U.T


with U a unitary real 8×8 matrix and T a real 8×8 upper triangular matrix (in which the terms on the diagonal are positive). By multiplying ZR by UT, we obtain:

ZR′=UT.ZR=T.SR′+WR

with







E


(


W
R




W
R







T



)


=



N
0

2



I
8







as U is unitary


The decoded word is defined ŜR=π.ŜR′ where ŜR′ is obtained coordinate by coordinate in the following manner:








s
^


R
,
8



=





z

R
,
8




t

8
,
8



+
0.5







For the coordinate 7, we refer the decision made on coordinate 8:








s
^


R
,
7



=






z

R
,
7



-


t

7
,
8





s
^


R
,
8






t

7
,
7



+
0.5







and so on until:








s
^


R
,
1



=






z

R
,
1



-




j
=
2

8




t

1
,
j





s
^


R
,
j







t

1
,
1



+
0.5







We will now describe the decoding algorithm by layers according to the present invention and, in particular, its impact on the general principle of the algorithms described above.


After MMSE-GDFE filtering, we carry out a permutation of Z, 203 on FIG. 2. by re-ordering the lines of Z. We then define the vector {tilde over (Z)} in the following manner:







Z
~

=

[




z

1
,
1







z

2
,
2







z

1
,
2







z

2
,
1





]






with the following convention






Z
=


[




z

1
,
1







z

2
,
1







z

1
,
2







z

2
,
2





]

.





From equation (2), it is easy to show that:







Z
~

=


2


K
M



R
~




Γ
~

·
S


+

W
~







with






R
~

=

[




r

1
,
1

1



0


0



i
·

r

1
,
2

1






0



r

2
,
2

2




r

2
,
1

2



0




0



r

1
,
2

2




r

1
,
1

2



0





r

2
,
1

1



0


0



i
·

r

2
,
2

1





]






and






Γ
~

=



1

5




[



α



α





θ



0


0





α
_





α
_



θ
_




0


0




0


0


α



α





θ





0


0



α
_





α
_



θ
_





]


=


1

5




[




C

α
,
θ





0

2
×
2







0

2
×
2





C

α
,
θ





]







It will be noted that the matrix {tilde over (R)} is an X matrix. We have also moved “i” from {tilde over (Γ)} to {tilde over (R)}.


Some definitions and properties:


Definition 1: X matrix: a matrix will be said to be an X matrix if all the coefficients outside the diagonal and the antidiagonal are nonexistent.


Proposition 1:


The product of two X matrices is an X matrix.


Definition 2:


Let (xj)1≦j≦4 be four elements of the ring of algebraic integers Z[i, θ] (where θ is an algebraic integer such that Q[i, θ] is an algebraic extension of degree 2 of Q[i]) and α an element of Z[i, θ], a matrix Δα(x1, x2, x3, x4) will be termed algebraic X if it is written:








Δ
α



(


x
1

,

x
2

,

x
3

,

x
4


)


=

[




x
1



0


0




α

α
_




x
4






0




x
_

1






α
_

α




x
_

4




0




0




α

α
_





x
_

2






x
_

3



0







α
_

α



x
2




0


0



x
3




]






where x is the algebraic conjugate of x.


Proposition 2:


Let Δα(x1, x2, x3, x4) be an algebraic X matrix, the determinant of Δα(x1, x2, x3, x4) is given by:

det(Δα(x1,x2,x3,x4))=NQ[i,θ]/Q[i](x1.x3−x2.x4)


where NQ[i,θ]/Q[i](x)=x. x designates the algebraic norm of x (for x in Q[i,θ] relative to Q[i]. The determinant of Δα(x1, x2, x3, x4) is an element of Z[i] since it is the norm of the algebraic integer x1x3−x2x4.


Proposition 3:


Let Δα(x1, x2 x3, x4) be an algebraic X matrix, then there exists a unique matrix πα(x1, x2, x3, x4) with coefficients in Z[i] such that:










Δ
α

(






x
1

,





x
2

,





x
3

,





x
4


)

·

[








C

α
,
θ





0

2
×
2







0

2
×
2





C

α
,
θ





]


=


[








C

α
,
θ





0

2
×
2







0

2
×
2





C

α
,
θ





]

·






Π
α

(






x
1

,





x
2





,





x
3

,





x
4






)














where






C

α
,
θ



=

[



α



α





θ






α
_





α
_

·

θ
_





]






is the matrix of the canonical embedding of the ideal aZ[i,θ] in Z[i]


In the case of the Golden Code, the matrix πα(x1, x2, x3, x4) is given by:








Π
α



(


x
1

,

x
2

,

x
3

,

x
4


)


=

[




x
1
1




x
2
1




x
1
4





x
1
4

-

x
2
4







x
2
1





x
1
1

+

x
2
1





x
2
4




-

x
1
4








x
1
2

+

x
2
2






x
1
2

+

2
·

x
2
2







x
1
3

+

x
2
3





-

x
2
3







-

x
2
2






-

x
1
2


-

x
2
2





-

x
2
3





x
1
3




]








where









j





1


j


4






x
j





=


x
1
j

+


θ
·

x
2
j








(



x
1
j






and






x
2
j




Z


[
i
]



)







Moreover, for the Golden Code, the matrix







1

5




C

α
,
θ







is unitary.


Proposition 4:


Let Δα(x1, x2, x3, x4) be an algebraic X matrix and πα(x1,x2, x3, x4) its associated matrix, then πα(x1, x2, x3, x4)εGL4(Z[i]) if and only if:

|NQ[i,θ]/Q[i]((x1.x3−x2.x4)|=1.


Similarly, we can define diamond matrices (nonexistant coefficients on the diagonal and the antidiagonal) likely to obtain good results.


After permutation of Z, a basis reduction, 204 on FIG. 2, termed algebraic reduction is carried out in the following manner.


Let Δα(x1, x2, x3, x4) be an algebraic X matrix with determinant of module 1 and πα(x1,x2,x3,x4) its associated matrix. πα(x1,x2, x3, x4) is an invertible matrix and its inverse has coefficients in Z[i].


We therefore have:

{tilde over (Z)}=2.KM{tilde over (R)}.{tilde over (Γ)}.S+{tilde over (W)}=2KM{tilde over (R)}.Δα(x1,x2,x3,x4).{tilde over (Γ)}.πα−1 (x1,x2,x3,x4).S+{tilde over (W)}
{tilde over (Z)}=2.KM.{tilde over (ψ)}.{tilde over (Γ)}.S′+{tilde over (W)}


By having put: {tilde over (ψ)}={tilde over (R)}.Δα(x1,x2,x3,x4) and S′=πα−1(x1,x2,x3,x4).S


The matrix {tilde over (ψ)} is an X matrix as well as a product of an X matrix. A reduction has therefore been carried out using the passage matrix πα(x1,x2,x3,x4) which has transformed the initial channel matrix {tilde over (R)} into an equivalent channel matrix {tilde over (ψ)}.


The aim of the algebraic reduction is therefore to find a matrix Δα(x1, x2, x3, x4) so that the matrix {tilde over (ψ)} has improved properties to allow the use of a simple decoding technique while at the same time obtaining good performance. To do this, two criteria are defined: a balance within each layer and a maximization of the power of the second layer. These criteria will be described in more detail in the following.


The sought properties of {tilde over (ψ)} therefore depend on the decoding algorithm employed.


The decoding by layer will now be described for a number of candidates: using the ZF-DFE algorithms, 205 on FIG. 2.


The decoding principle for p candidates is as follows.


The decoding algorithm consists of determining p possible candidates for layer 2. For each of the p layer 2 candidates, the closest value for layer 1 is determined, while reporting the decision made on layer 2 (as for the DFE method). Within each of the layers, the decoding technique is ZF made virtually optimal by algebraic reduction (step 2 of the reduction). The number of candidates, p, is a relatively low number: p=2 is, for example, an excellent compromise between complexity and performance. From the perspective of a real time system that is easy to implement, it is preferable to fix the value of p. However, more complex strategies for determining p, as a function of the matrix {tilde over (ψ)} could be envisaged.

    • The QR Decomposition


Let us suppose that the reduction has already been carried out; we then have:

{tilde over (Z)}=2KM.{tilde over (ψ)}.{tilde over (Γ)}.S′+{tilde over (W)}


A QR decomposition of the matrix {tilde over (ψ)} is carried out:







Ψ
~

=


[




Ψ

1
,
1

1



0


0



i
.

Ψ

1
,
2

1






0



Ψ

2
,
2

2




Ψ

2
,
1

2



0




0



Ψ

1
,
2

2




Ψ

1
,
1

2



0





Ψ

2
,
1

1



0


0



i
.

Ψ

2
,
2

1





]

=

U
·
T






with U a unitary 4×4 complex matrix (UHU=I4) and T a upper triangular 4×4 complex matrix in which the diagonal terms are real and positive. In addition, U and T have a particular structure:






U
=



[




u

1
,
1




0


0



u

1
,
4






0



u

2
,
2





u

2
,
3




0




0



u

3
,
2





u

3
,
3




0





u

4
,
1




0


0



u

4
,
4





]






and





T

=

[




t

1
,
1




0


0



t

1
,
4






0



t

2
,
2





t

2
,
3




0




0


0



t

3
,
3




0




0


0


0



t

4
,
4





]






Given the form of {tilde over (ψ)}, its QR decomposition is equivalent to the QR decomposition of 2 2×2 matrices:







[




Ψ

1
,
1

1




i
.

Ψ

1
,
2

1







Ψ

2
,
1

1




i
.

Ψ

2
,
2

1





]

=



[




u

1
,
1





u

1
,
4







u

4
,
1





u

4
,
4





]

·


[




t

1
,
1





t

1
,
4






0



t

4
,
4





]





[




Ψ

2
,
2

2




Ψ

2
,
1

2






Ψ

1
,
2

2




Ψ

1
,
1

2




]


=


[




u

2
,
2





u

2
,
3







u

3
,
2





u

3
,
3





]

·

[




t

2
,
2





t

2
,
3






0



t

3
,
3





]







We then have:

{tilde over (Z)}=2KM.U.T.{tilde over (Γ)}.S′+{tilde over (W)}


By multiplying by UH, we obtain:

{tilde over (Z)}′=UH.{tilde over (Z)}=2KMT.{tilde over (Γ)}.S′+{tilde over (W)}′


with E({tilde over (W)}′{tilde over (W)}′H)=N0.I4 since U is unitary.

    • The extraction of p candidates by ZF for the second layer.


The last two components of {tilde over (Z)}′ are:







[





z
~

3








z
~

4





]

=



2
·

K
m

·

[




t

3
,
3




0




0



t

4
,
4





]

·

1

5






C

α
,
θ


·

[




s
3







s
4





]



+

[





w
~

3








w
~

4





]






By applying a ZF (by multiplying by the inverse matrix), we obtain:








S
~

2


=


1


2
·

K
M




5



·

C

α
,
θ

H

·


[




1
/

t

3
,
3





0




0



1
/

t

4
,
4






]



[





z
~

3








z
~

4





]







From which:








S
~

2


=


[




s
3







s
4





]

+


1


2
·

K
M




5



·

C

α
,
θ

H

·

[




1
/

t

3
,
3





0




0



1
/

t

4
,
4






]

·

[





w
~

3








w
~

4





]







Starting from the vector {tilde over (S)}′2, a list of distinct 2×2 Z[i]2 p vectors is established {Ŝ′21, . . . , Ŝ′2p} closest to {tilde over (S)}′2.

    • The ZF decoding of the first layer after referring p candidates


For each of p vectors Ŝ′2j (1≦j≦p), a vector Ŝ′1j is calculated by rounding each of the coordinates of {tilde over (S)}′1j defined as follows:








S
~

1







j


=


1


2
·

K
M




5



·

C

α
,
θ

H

·

[




1
/

t

1
,
1





0




0



1
/

t

2
,
2






]

·

(





[





z
~

1








z
~

2





]

-

2
·

K
M

·











[



0



t

1
,
4







t

2
,
3




0



]

·







1

5





C

α
,
θ


·


S
^

2







j










)






The vector Ŝ′j is constructed:








S
^








j


=

[





S
^

1







j








S
^

2







j





]





The vector Ŝ′j is reduced in the initial base to obtain Ŝj:

Ŝjα(x1,x2,x3,x4).{circumflex over (S)}′j


Thus a list of p distinct {Ŝ1, . . . Ŝp} two by two Z[i]4 candidate vectors to be the decoded vector Ŝ is prepared.

    • determination of the best candidate.


Each of the vectors Ŝj, is tested for membership of the shaping region. In this way, we build a sub-list of the preceding list, while keeping only the vectors meeting the shaping condition. This list of k vectors (with 0≦k≦p) will be noted: {Ŝσ(1), . . . , Ŝσ(k)}.). It is necessary to distinguish 2 cases:

    • k=0. Several strategies can be adopted without serious consequences on performance. For example, we can choose to saturate the coordinates of Ŝ′ which do not meet the shaping condition, in order to obtain the decoded vectors Ŝ.
    • k≧1. In this case, the decoded vector Ŝ is defined as follows:







S
^

=

Arg
(


Min

1

j

k








Z
~

-


2
·

K
M





R
~

·

Γ
~

·


S
^


σ


(
j
)








2


)





We will repeat below the criteria for {tilde over (ψ)} during the reduction algorithm.

    • equilibrium within each layer.


For each of the layers, a ZF decoding will be used. For the layer j (1≦j≦2), the 2×2 matrix Aj to be inverted is presented as follows:







A
j

=


2
·

K
M

·

[




t



2
·
j

-
1

,


2
·
j

-
1





0




0



t


2
·
j

,

2
·
j






]

·

1

5





C

α
,
θ







Given that the matrix







1

5




C

α
,
θ







is unitary, if t2.j-1, 2.j-1 and t2.j,2.j are equal, then the matrix Aj is proportional to a unitary matrix, which would make the ZF decoding equivalent to Maximum Likelihood within each of the layers. The aim of the reduction within layer j is therefore to equalize as far as possible the coefficients t2.j-1, 2.j-1 and t2.j,2.j.

    • to maximize the power of layer 2.


In order that the proposed decoder has the came behaviour as Maximum Likelihood, it is necessary that, from the p points chosen during decoding the second layer, one of them corresponds to that which the Maximum Likelihood decoder has decoded. To do this, it is necessary to maximize the product t3,3.t4,4.


Given that the reduction does not modify the determinant module of T (i.e. the product t1,1.t2,2.t3,3.t4,4), maximizing the product t3,3.t4,4 is equivalent to minimizing the product t1,1.t2,2.


It is important to note that:







t

1
,
1


=





Ψ
~

1



=







i
=
1

4







Ψ
~


i
,
1




2








et






t

2
,
2



=





Ψ
~

2



=





i
=
1

4







Ψ
~


i
,
2




2










An example of a reduction algorithm will now be described, taking into account the two criteria of equilibrium and maximization.


Principle of the Reduction Algorithm:


The algebraic reduction algorithm is carried out in two steps:

    • The first step consists in determining a first quadruplet (β1, β2, β3, β4) of algebraic integers which will allow minimization of the product ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥ where the matrix {tilde over (φ)} is given by:

      {tilde over (φ)}={tilde over (R)}.Δα1234)
    • The second step consists of balancing each of the layers once the first step is completed. This step does not modify the balance between the layers, i.e. we will have

      ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥=∥{tilde over (ψ)}1∥.∥{tilde over (ψ)}2


Preliminary Mathematics:


If we have: {tilde over (φ)}={tilde over (R)}.Δα1234)


It will be noted that for a given matrix {tilde over (R)}:

    • ∥{tilde over (φ)}1∥ depends only on (β12) which will be denoted ∥{tilde over (φ)}1∥(β12):











Φ
~

1





(


β
1

,

β
2


)


=








r

1
,
1

1

·

β
1


+


i
.

r


1
,
2






1





α
_

α



β
2





2

+






r

2
,
1

1

·

β
1


+


i
.

r

2
,
2

1





α
_

α



β
2





2









    • ∥{tilde over (φ)}2∥ depends only on ( β1, β2):














Φ
~

2





(



β
_

1

,


β
_

2


)


=








r

2
,
2

2

·


β
_

1


+


r

2
,
1

2



α

α
_





β
_

2





2

+






r

1
,
2

2

·


β
_

1


+


r

1
,
1

2



α

α
_





β
_

2





2







Definition:


A unit of a number field Q[i,θ] is an element of Z[i,θ] the inverse of which is also in Z[i,θ]. Any unit of Q[i,θ] has an algebraic norm relative to a Q[i] which belongs to {1,−1, i, −i}.


Dirichlet's Theorem in a Real Quadratic Field:


Let Q[θ] be a totally real algebraic extension of Q of degree 2. Then a unit exists, called fundamental unit μ, such that any unit u of Q[θ] can be written: u=(±1).μk with kεZ


Comment:


In the case of the Golden Code, we can take μ=θ


Proposition 5:


If the pair (β1, β2) of algebraic integers from Z[i,θ] minimises the product ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥, then β1 and β2 have no common multiples other than units of Z[i,θ].


Proof:


Let us suppose that (β1, β2) minimises ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥ and that xεZ[i,θ] exist such that β1=x.γ1 et β2=x.γ2. Then

∥{tilde over (φ)}1∥(β12).∥{tilde over (φ)}2∥( β1, β2)=|NQ[i,θ]/Q[i](x)∥{tilde over (φ)}1∥(γ12).∥{tilde over (φ)}2∥( γ1, γ2)


from which |NQ[i,θ]/Q[i](x)=1.


Therefore x is a unit of Z[i,θ].


Proposition 6:


If the ring of algebraic integers Z[i,θ] is a PID (Principal Integral Domain), which is the case for the Golden Code, and if in addition β1 and β2 are two algebraic integers of Z[i,θ], which have no common multiples other than units of Z[i,θ], then two algebraic integers β3 and β4 exist such that:

β13−β24=1


Proof:


From proposal 5, we use a generalisation of Bézout's theorem in a PID, or even in particular the document: H. Cohen, “A Course in Computational Algebraic Number Theory”, Springer, 1996.


Proposition 7:


If the pair (β1, β2) of algebraic integers of Z[i,θ] minimises the product ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥ and if, in addition Z[i,θ] is a PID, then there are two algebraic integers β3 and β4 of Z[i,θ] (which are determined by resolving β13−β24=1) such that πα1234)εGL4(Z[i])


Proposition 8:


Let μ be a fundamental unit of Z[i,θ] with |μ|>1. Let (γ12)εZ[i,θ]2, then (β12)εZ[i,θ]2 exists such that:











Φ
~

1






(


β
1

,

β
2


)

·




Φ
~

2






(



β
_

1

,


β
_

2


)


=





Φ
~

1






(


Y
1

,

Y
2


)

·




Φ
~

2






(



Y
_

1

,


Y
_

2


)







and












Φ
~

1



2



(


β
1

,

β
2


)


+






Φ
~

2



2



(



β
_

1

,


β
_

2


)









Φ
~

1






(


β
1

,

β
2


)

·




Φ
~

2







(



β
_

1

,


β
_

2


)

·

(



μ


+

1


μ




)







Proof:







Let





k

=







ln


(





Φ
~

1





(


Y
1

,

Y
2


)


)


-

ln


(





Φ
~

2





(



Y
_

1

,


Y
_

2


)


)




ln


(



μ


2

)



+
0.5



.





We take:







β
1

=



μ

-
k




Y
1


et






β
2


=


μ

-
k




Y
2









Then





we





have











Φ
~

1






(


β
1

,

β
2


)

·




Φ
~

2






(



β
_

1

,


β
_

2


)


=





Φ
~

1






(


Y
1

,

Y
2


)

·




Φ
~

2






(



Y
_

1

,


Y
_

2


)









and







Max


(






Φ
~

1





(


β
1

,

β
2


)


,





Φ
~

2





(



β
_

1

,


β
_

2


)



)



Min


(






Φ
~

1





(


β
1

,

β
2


)


,





Φ
~

2





(



β
_

1

,


β
_

2


)



)







μ






We then easily obtain:













Φ
~

1



2



(


β
1

,

β
2


)


+






Φ
~

2



2



(



β
_

1

,


β
_

2


)









Φ
~

1






(


β
1

,

β
2


)

·




Φ
~

2







(



β
_

1

,


β
_

2


)

·

(



μ


+

1


μ




)







First step: balance between layers:

    • Search for (β12)εZ[i,θ]2


First of all, we search for the pair (β12)εZ[i,θ]2 which minimizes ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥.


The determination of (β12)εZ[i,θ]2 is equivalent to the determination of the vector B of Z[i]4 defined by:






B
=



·

[




β
1
1






β
2
1






β
1
2






β
2
2




]







where






β
j


=


β
j
1

+

θ
·

β
j
2








By setting:









Ω
=



[




ω
1






ω
2






ω
3






ω
4




]







=






[




r

1
,
1

1



0



i
·

r

1
,
2

1




0





r

2
,
1

1



0



i
·

r

2
,
2

1




0




0



r

2
,
2

2



0



r

2
,
1

2





0



r

1
,
2

2



0



r

1
,
1

2




]

·

[



1


θ


0


0




1



θ
_



0


0




0


0




α
_

α






α
_

α


θ





0


0



α

α
_






α

α
_




θ
_





]






G

α
,
θ




(
R
)




·

[




β
1
1






β
2
1






β
1
2






β
2
2




]








=





G

α
,
θ




(
R
)


·
B








We therefore have:

∥{tilde over (φ)}12=|ω1|22|2
∥{tilde over (φ)}22=|ω3|24|2


The search algorithm runs as follows:


Initialization:


Search for the shortest vector of the lattice generated by the columns of Gα,θ(R). Bmin is initialized by the coordinates of one of the shortest vectors of this lattice:







B

m





i





n




Arg
(


Min


B



Z


[
i
]


4



B

0










G

α
,
θ




(
R
)


·
B



2


)





The value of ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥ is calculated for Bmin this value is annotated ρ.


Search in a List:


We prepare the list, annotated L, of the vectors of the lattice generated by the columns of Gα,θ(R) which have a square norm less than or equal to







ρ
·

(



μ


+

1


μ




)








i
.
e
.

:








L
=

{

B





Z


[
i
]


4


B



0





such





that











G

α
,
θ




(
R
)


·
B



2




ρ


(



μ


+

1


μ




)




}





For each of the elements of the list, we calculate the value of ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥, Bmin is the element of this list which minimises ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥.


Using Proposition 8, it is evident that the pair (β12)εZ[i,θ]2 obtained using Bmin minimises the product ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥.

    • determination of (β34)εZ[i,θ]2:


After having determined the pair (β12)εZ[i,θ]2 which minimises the product ∥{tilde over (φ)}1∥.∥{tilde over (φ)}2∥, it suffices to resolve the equation β13−β24=1, which has a solution according Proposition 7, in order to determine the pair (β34) Z[i,θ]2. Such an equation is reduced to a system of 4 equations with 8 unknowns with coefficients in Z, in which solutions are sought in Z8. This type of system is easily resolved by putting a rectangular matrix with integer coefficients in HNF form (see H Cohen).

    • Second step: balance within the layers:


On completion of the first step, we have:

{tilde over (φ)}={tilde over (R)}.Δα1234)


A QR decomposition of {tilde over (φ)} is carried out:

{tilde over (φ)}=U.T


For each layer j (1≦j≦2), we define:







k
j

=






ln


(

t


2
·
j

,

2
·
j



)


-

ln


(

t




2
·
j

+
1

,


2
·
j

+
1








)




ln


(



μ


2

)



+
0.5







In this second step, we will use the reduction matrix

Δα−k1,0,μ−k2,0)


It will be noted that its associated matrix πα−k1,0,μ−k2,0) is certainly in GL4(Z[i]) thanks to Proposition 4 and to the fact that μ−k1−k2 is a unit and therefore |NQ[i,θ]/Q[i]−k1−k2)|=1

    • Conclusion of the reduction algorithm.


In conclusion, we define:

{tilde over (ψ)}={tilde over (R)}.Δα1234).Δα−k1,0,μ−k2,0)={tilde over (R)}Δα(x1,x2,x3,x4)


with x11−k1, x22−k1, x33−k2 and x44−k2


The curve on the single FIGURE has the decoder performances for two values of p (p=1 and p=2) compared with those of the Maximum Likelihood decoder and those of the MMSE-GDFE LLL ZF-DFE decoder. The performances are expressed in PER (Packet Error Rate), depending in the Signal to Noise Ratio (SNR) in dB.


Of course, the invention is not limited to the examples which have just been described and numerous adjustments can be made to these examples without exceeding the scope of the invention. The use of diamond matrices instead of X matrices can be envisaged for basis reduction and for decoding. Furthermore, the first step of the algebraic reduction algorithm may also not be carried out or it can be modified to make it easier to execute. However, to compensate for this drop in quality of the reduction, it will be necessary to take a fairly high value of p.

Claims
  • 1. A method for decoding 2×2 space-time codes of a vector Y, in particular of the Golden Code type, the decoding method comprising a decoder for performing the following steps: a filtering of the minimum mean square error-generalized decision feedback equalizer (MMSE-GDFE) type is carried out by the decoder in order to obtain a vector YF=RX+W, with YF the vector Y filtered by means of a filter matrix F (“forward filter”), R a conventional matrix named “backward filter”, X the vector transmitted and W the complex noise matrix;a constellation recentring is carried out by the decoder so that the vector to be determined becomes Z, such that Z=YF−2KMRΓS0=2KMRΓS+W, KM being the normalization constant for the constellation in question, F being the Golden Code, and S the vector of the information symbols;a step of permutation of the elements of the matrices Z, R and F is carried out by the decoder in order to obtain {tilde over (Z)}, {tilde over (R)} and {tilde over (Γ)} such that {tilde over (R)}HR is a matrix in the form of an X and the complex number “i” is moved from Γ to R;a step of lattice basis reduction is carried out by the decoder such that {tilde over (Z)}=2KM{tilde over (Ψ)}{tilde over (Γ)}S′+W with {tilde over (Ψ)}={tilde over (R)}.Δα(x1, x2, x3, x4) and S′=πα−1(x1, x2, x3, x4).S, πα(x1, x2, x3, x4) being a basis change matrix, πα(x1, x2, x3, x4) is the matrix associated with Δα(x1, x2, x3, x4) which is a matrix in which the determinant module is equal to 1 and defined such that ΔαHΔα is a matrix in the form of an X; andthe zero forcing-decision feedback equalizer (ZF-DFE) decoding algorithm is applied by the decoder, in which among the four elements of two layers are identified, each layer comprising the two elements of the diagonal or anti-diagonal of {tilde over (Z)}; the DFE algorithm is applied layer by layer and the ZF algorithm within each of the layers.
  • 2. The method according to claim 1, characterized in that the permutation of {tilde over (Z)} is as follows:
  • 3. The method according to claim 2, characterized in that {tilde over (R)} is a matrix in the form of an X such that:
  • 4. The method according to claim 1 wherein:
  • 5. The method according to claim 1, characterized in that Δα is determined such that, during a QR decomposition, both elements of a single layer are substantially of the same value.
  • 6. The method according to claim 1, characterized in that {tilde over (Z)} is defined as two layers, a first layer consisting of elements on the diagonal and a second layer consisting of elements on the anti-diagonal, and in that Δα is determined such that, during a QR decomposition, the product of the two elements of the second layer is greater than the product of the two elements of the first layer.
  • 7. The method according to claim 1, characterized in that {tilde over (Z)} is defined as two layers, a first layer composed of elements on the diagonal and a second layer composed of elements on the anti-diagonal, and in that during application of the ZF algorithm for the second layer, p possible candidates are extracted, then for the first layer p possible candidates are also extracted and then the best candidate vector is determined.
  • 8. The method according to claim 7, characterized in that p is equal to 2.
  • 9. The method according to claim 1, characterized in that {tilde over (R)} and Δα are X matrices.
  • 10. The method according to claim 1, characterized in that {tilde over (R)} and Δα are diagonal matrices.
Priority Claims (1)
Number Date Country Kind
06 04429 May 2006 FR national
PCT Information
Filing Document Filing Date Country Kind 371c Date
PCT/FR2007/000798 5/11/2007 WO 00 7/23/2009
Publishing Document Publishing Date Country Kind
WO2007/132084 11/22/2007 WO A
US Referenced Citations (2)
Number Name Date Kind
7292647 Giannakis et al. Nov 2007 B1
20070217537 Berenguer et al. Sep 2007 A1
Related Publications (1)
Number Date Country
20100034320 A1 Feb 2010 US