In many communication systems, codes are used to represent data during transmission of the data. The codes may have some built in redundancy in order to ensure communications are properly received. Several things may interfere with transmission, and the amount of redundancy built into various codes may vary to ensure proper reception in different settings. For instance, noise may be more prevalent in industrial settings, and it may be more important for the information to be properly received. In such a setting, a higher redundancy code may be used for transmission. Signals may also travel on multiple paths, and multiple signals from different transmissions may be mixed in with the codes being transmitted. All these factors may be taken into account when selecting codes during design of a communication system.
Block group codes are widely used in block-coded modulation schemes. The construction of these codes is important because if sets with more than two signals are used for transmission, then group structures (rather than field-like structures) match the relevant distance measure of a given channel.
Since the full potential of block-coded modulation schemes may be achieved by using soft-decision decoding, Trellis based decoding becomes very attractive for block group codes.
A Trellis is an edge labeled graph. In such a graph, there exists a pair of vertices called the root and toor, at which the Trellis commences and terminates. These are the leftmost and the rightmost vertices respectively. Each path from the root vertex to the toor vertex represents a valid codeword in the code which the Trellis represents. To get the codewords, the labels of the edges of a path are concatenated.
The Trellis of a code is used for soft-decision decoding of linear or rectangular codes. Trellises permit Maximum-likelihood (ML) decoding. In this type of decoding, the codewords of the code which are most likely to have been transmitted are determined, given the codeword (possibly distorted by noise) which was received is known. The parameters of the Trellis (like the number of vertices) of a block group code determine the complexity of decoding. Therefore considerable work has been done on constructing minimal trellises for block codes.
Various trellis construction techniques are known for codes over finite fields, including a Massey and a BCJR approach. KS (Kalman smoother) construction has been described for a minimal trellis construction approach for block codes over finite abelian groups.
In the following description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific embodiments which may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that structural, logical and electrical changes may be made without departing from the scope of the present invention. The following description of example embodiments is, therefore, not to be taken in a limited sense, and the scope of the present invention is defined by the appended claims.
The functions or algorithms described herein may be implemented in software or a combination of software and human implemented procedures in one embodiment. The software may consist of computer executable instructions stored on computer readable media such as memory or other type of storage devices. The term “computer readable media” is also used to represent any means by which the computer readable instructions may be received by the computer, such as by different forms of wired or wireless transmissions. Further, such functions correspond to modules, which are software, hardware, firmware or any combination thereof. Multiple functions may be performed in one or more modules as desired, and the embodiments described are merely examples. The software may be executed on a digital signal processor, ASIC, microprocessor, or other type of processor operating on a computer system, such as a personal computer, server or other computer system.
A Trellis is an edge labeled graph 100, as shown in
A Massey and BCJR approach for minimal trellis construction for codes over finite abelian groups is described in some embodiments. Constructing a Massey trellis is described given the generator matrix of the code. The BCJR approach for trellis construction utilizes a parity check matrix of the code. Proof of minimality of the construction and discussion of the algorithmic complexities of these techniques is also offered. Concrete examples are provided for both approaches.
The description is organized in the following manner. A brief introduction on block codes over finite abelian groups is first provided. The Massey approach for trellis construction and the minimality of the approach is also provided. Given a parity check matrix of a block group code its minimal trellis can be constructed using the BCJR algorithm. The BCJR based trellis construction is then provided.
Let G be a finite abelian group. The subgroups of Gn are called n length group codes. A group code of length n can be seen as a linear code of length mn over GF(p). Further, a generator matrix Ψ is constructed for such a code using endomorphisms over 1≦i≦m Zp. Ψ is a k×n matrix of endomorphisms where ψi,j represents the i,j'th entry of the matrix such that ψi,j: 1≦i≦m Zp→1≦i≦m Zp. This generator matrix can be used like the generator matrices of block linear codes over fields for tasks such as generating the codewords, given the information set, etc. This generator matrix can also be used for Massey construction of the minimal Trellis, just like generator matrices for codes over fields.
An (n, k) systematic group code C is a code over Gn of order |G|k defined by n−k homomorphisms {φj}, such that 1≦j≦(n−k). The codewords of C can be written as
(x1, . . . , xk, φ1(x1, . . . , xk), φ2(x1, . . . , xk), . . . , φn−k(x1, . . . xk)). Here xk+j=φj(x1, . . . , xk). By the definition of the homomorphism φ, previous expression is rewritten as
x
k+j=⊕i≦1≦kφj(e, . . . , x1, . . . e) (1)
Since φj(e1, . . . , x1, . . . e)εG, φj(e1, . . . x1, . . . e) can be expressed as ψ1,j(x1), where ψi,j are endomorphisms over G. Hence,
x
k+j=⊕i≦1≦kψi,j(xi) (2)
Therefore for systematic codes, the generator matrix can be written as G=[I|ψ]
Codewords are formed as
(x1, . . . xn)=[x1, . . . xk]G (4)
Since any finite abelian group can be expressed as G≡Cd
x=⊕1≦i≦mxβ,igi (5)
Now, consider the endomorphisms ψi,j themselves, let
ψ(gi)=1≦j≦mαi,jgj (6)
Then, ψ, can be written as
Thus, using equation (5) and equation (6), ψ(x) can be written as
Given a generator matrix of a group code C, a Theorem 1 helps us construct the generator matrix of the dual code C⊥. This is nothing but the parity check matrix of C. This parity check matrix is used to construct a BCJR trellis for C later in the description.
Massey Construction for Codes Over Finite Abelian Group Codes
Massey construction is a technique for obtaining a minimal trellis for any linear block code over finite fields. The technique is applied herein for finite group codes.
Consider an example where p=2 and every element q of G can be written in terms of the products of the underlying elements over GF(2). For example, in a code C={0, x, y, xy}, the elements may be represented in terms of C2×C2 as follows
0→(0,0),x→(0,1),y→(1,0),xy→(1,1)
Hence, the 2×2 endomorphisms ψi,j could be like
The generator matrix of a (2, 3) code would be of the form
The matrix above could be considered to be a 2k×2n matrix over GF(2) and an algorithm 200 in
In applying algorithm 200 to the code mentioned above, the generator matrix of the code is as follows (after the various 2×2 endomorphisms are considered as one large matrix:
Using algorithm 200, a row-reduced echleon matrix is obtained:
ψ′, may be used to construct the Massey trellis for it. Let the resulting minimal trellis be T. The starting position of a row x in A′ is designated as (x). Further, the columns of ψ′ of weight one are represented as (γ1, γ2, . . . γk).
Vertices in T at time instant i (represented as Vi) are the equivalence classes represented by (ci+1, ci+2, . . . cn) where
(c1,c2, . . . , cn)=(a1,a2, . . . am,0,0,0)Ψ′
where (a1, a2, . . . am) is the set of information symbols of the input such that
m=max{jε(γ1,γ2, . . . γk):j≦i}
Or
V
i≅(ci+1,ci+2, . . . cn) (12)
For the trellis, beginning the initial vertex φ called the root vertex of T at time 0, the equivalence classes at time 1 are
Hence there will be two vertices. The equivalence classes at later times are shown below. At time 2,
Proof that Massey Construction Produces the Minimal Trellis
THEOREM III. 1. The Massey construction as per algorithm 200 is minimal
Proof: We will prove that the resulting Massey trellis over a group is two way proper, which is sufficient to prove it is minimal. First we prove the forward proper property.
Let T be a Massey Trellis for a code C. Let γm=i. Let am be the m'th information symbol. The states in the Massey trellis are the equivalence classes represented by
V
i≡(a1, . . . , am,0, . . . , 0)Gk×(m+1,n) (13)
Where Gk×(m+1,n) represents the k rows and the columns m+1, . . . n of the generator matrix G. Consider a particular vertex vεVi−1 in T. It can be represented as a1, . . . , am−1, 0, . . . , 0)Gk×(m+1,n) for some fixed a1, . . . , am−1. the vertex v can be represented by the sum Σi−1≦j≦nΣ1≦k≦m−1cj,kak, where cm,n represents the element in the m'th column and n'th row of G. For this codeword to reach a vertex in the i'th section of the trellis, another information symbol is to be added and the information set becomes (a1, . . . , am−1,x). The vertex v′εVi+1 corresponding to these information symbols can be represented as v′=Σi−1≦j≦nΣ1≦k≦m−1cj,kak+xΣi−1≦j≦ncm,j. Clearly, for different values of x, the sum will be different and hence the trellis is forward proper.
The reverse case may now be proved. Consider two distinct vertices v and v′εVi represented by (a1, . . . , am, 0, . . . , 0)Gk×i+1,n and (a′1, . . . , a′m, 0, . . . , 0)Gk×i+1,n, Let v″εVi+1 such that codewords from v and v′converge at v″. Then, since no additional information symbol is introduced at the i+1'th section, the sums of both information sets must be the same as shown below at the i+1'th section of the trellis. This means that (a1, . . . , am, 0, . . . 0)Gk×i+2,n=(a′1, . . . , a′m, 0, . . . , 0)Gk×i+2,n. However, the sums are different at the i'th section which means that (a1, . . . , am, 0 . . . , 0)Gk×i+1,n=(a′1, a′m, 0, . . . , 0)Gk×i+1,n
Expanding these two conditions:
The above two equations imply that
The LHS and RHS of the above equations are the edge labels from vertex v to v″ and v′ to v″ respectively. Hence, all converging states have distinct labels, which completes the proof that the trellis is proper in the reverse case.
BCJR Trellis for Group Codes
An alternative method 1000 in
An algorithm for constructing the minimal trellis for a linear block code over GF(p) is extended for construction of group codes over Finite Abelian groups. The purpose of any technique for constructing a minimal trellis is to determine the set of vertices at time i in the trellis (denoted by Vi). Let Pi−(C) represent the codeword pasts, where C is a linear block code of length n and 1≦i≦n. Let H be the parity check matrix of the code C.
According to [1], if cεPi−(C), then the equivalence classes formed by the syndrome HcT represents the future equivalences, Vi. In one example, consider a (4, 2) group code over C22 with the generator matrix (equation 14) and parity check matrix (equation 15). A minimal trellis is constructed for this code using the BCJR technique.
Instead of the usual code alphabet, the matrices G and H above consist of 2×2 matrices which, are endomorphisms as required by equation (3). A BCJR trellis is constructed over the above code. Looking at C22={00, 01, 10, 11}, it is observed that it is generated by the vectors g1=01 and g2=10. Or,
<g1,g2>=C22
Hence,
There is one vertex at time i=1 and is called the root vertex. To see how many vertices there are, at i=2, the syndromes H1p1T are calculated:
which leads to the conclusion that there are four distinct vertices at time i=2.
Similarly, at i=3, calculate the syndromes) H3p3T. The following syndromes are obtained:
Clearly, all 16 syndromes are distinct and there are 16 vertices at this stage of the trellis.
At time i=4, the following syndromes are obtained
From the above syndromes, it is seen that there are four vertices at this stage of the trellis with syndromes
At time i=5, p4 will constitute of codewords from C and hence all the syndromes will be
(null vector) by definition. This single vertex at this stage of the trellis is called the toor.
Receiver 900 in
Proof of Minimality of the proposed BCJR technique
THEOREM IV.1. The Trellis created by algorithm 300 in
Proof: The proof of minimality is similar to the proof of minimality of a BCJR trellis over a finite field. The concepts of ˜T equivalence (denoted as ˜T) and future equivalence (denoted as ˜) are used.
Let c1, c2εC, where C is a length n linear block code. For some iε[1, n], if Pi(c1)˜TPi(c2), then it always follows that Pi(c1)˜Pi(c2). For a minimal trellis, the reverse also holds true, i.e Pi(c1)˜Pi(c2) always implies that Pi(c1)˜T Pi(c2). Given codewords c, c′εC such that c=(c1, c2, . . . , cn) and c′=(c′1, c′2, . . . , c′n), we have
If c and c′ are future equivalent at time i, they must share a common future after the i'th section of the trellis. Let that common future be x=xi+1, . . . xn. Then, H (Pi(c),x)=H(Pi(c′),x), which means that
c
1
H
1
+ . . . +c
i
H
i=−(xi+iHi+1+ . . . +xnHn)
which in turn is equal to c′1H1+ . . . +c′iHi. Both the above equations imply that c and c are T-equivalent at some vertex of the trellis at section i. Hence, future equivalence implies T-equivalence, completing the proof.
The task of Minimal Trellis construction includes
1) Conversion of whichever matrix is used for the construction to a desired form. This includes converting a generator matrix to a two-way proper form for the KS method, a row-reduced echleon format for the Massey method etc.
2) Obtaining the number of vertices (represented as |Vi(T)|) in each section of the trellis.
3) Determining the edge transitions between states of the trellis (E(T)). It is assumed throughout the section that the computation (group operation in one embodiment) takes a unit amount of computing power.
Since any parity check matrix can be used for calculating the syndromes HiciT, the complexity of matrix conversion is Zero.
To determine the number of vertices in the minimal trellis at any time, all the syndromes are calculated. Algorithm 500 in
Σi≦i≦nn|C|Vi+1|,≈n|C∥V(T)|
The generator matrix for the Massey Trellis may be reduced to the row reduced echleon form. This is bounded by O(k2n). The task of determining the vertex sets and edge transitions is the same as for a BCJR trellis as both these techniques rely on calculating syndromes.
The generator matrix for the KS Trellis is bounded by O(k2n). Let the group G from which the code is generated be isomorphic to Zq. The number of vertices at the i'th time instant in the KS trellis is qri, where ri is the number of rows active at time i. The algorithm which keeps track of how many rows are active at time i in a generator matrix is of order O(kn).
Every vertex in the KS trellis at time i can be written as v1× . . . ×vk, where vi belongs to the minimal trellis formed by the i'th row alone. This is because the KS trellis is a product trellis. Similarly, every vertex at time i+1 can be written as v′1× . . . ×v′k. An algorithm 700 in
In various embodiments, the BCJR technique of trellis generation may be done without manipulation of the parity check matrix before being used for trellis construction. This is not the case for Massey and KS techniques. This makes the BCJR technique computationally attractive when compared to the other techniques. For high rate codes, the parity check matrices are sparse and the BCJR technique is more computationally efficient as it uses a parity check matrix rather than using a generator matrix.
A block diagram of a computer system that may be used to execute programming for performing the above algorithms is shown in
Computer-readable instructions stored on a computer-readable medium are executable by the processing unit 1102 of the computer 1110. A hard drive, CD-ROM, and RAM are some examples of articles including a computer-readable medium.
The Abstract is provided to comply with 37 C.F.R. § 1.72(b) to allow the reader to quickly ascertain the nature and gist of the technical disclosure. The Abstract is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims.
This patent application claims the benefit of priority, under 35 U.S.C. Section 119(e) to U.S. Provisional Patent Application Ser. No. 60/925,773, entitled “Trellis Construction for Group Codes”, filed on Apr. 23, 2007, which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
60925773 | Apr 2007 | US |