# An Investigation of Quaternary [5,3] Error Correcting Codes and their Implementation with Binary Devices 

Research Article

A.K.M. Toyarak Rian ${ }^{1}$, Partha Pratim Dey ${ }^{2, *}$, Farzana Karim Elora ${ }^{1}$<br>${ }^{1}$ Department of Electrical and Computer Engineering, North South University, Bangladesh<br>${ }^{2}$ Department of Mathematics and Physics, North South University, Bangladesh<br>*Corresponding author: ppd@northsouth.edu


#### Abstract

In this paper we investigate the existence, equivalence and some other features of quaternary [ 5,3$]$ error correcting codes. We also discuss the binary hardware devices that could be used to code and decode messages when these [5,3] error-correcting codes are used.


Keywords. Generalized linear code; Generator matrix; Equivalent code; Gates
MSC. 53C15; 53C25
Received: November 7, 2014 Accepted: December 15, 2014
Copyright © 2015 A.K.M. Toyarak Rian, Partha Pratim Dey and Farzana Karim Elora. This is an open access article distributed under the Creative Commons Attribution License, which permits unrestricted use, distribution, and reproduction in any medium, provided the original work is properly cited.

## 1. Introduction

Let $F$ be the $\operatorname{GF}(q)$, the Galois field with $q$ elements. An [ $n, k]$ linear code over $\operatorname{GF}(q)$ is a $k$-dimensional subspace of $F^{n}$, the space of all $n$-tuples with components from $F$. Since a linear code is a vector sub-space, it can be given by a basis. A generator matrix is a $k \times n$ dimensional matrix whose rows are the basis vectors of the code. For an acquaintance with coding theory at a basic level, the reader may please consult [1, 2, 3].

A very important concept in coding is the weight of a vector $v$. By definition, this is the number of non-zero components $v$ has and is denoted by $w t(v)$. The minimum weight of a code, denoted by $d$ is the weight of a non-zero vector of smallest weight in the code. A well-known theorem says that if $d$ is the minimum weight of a code $C$, then $C$ can correct $t=\left\lfloor\frac{d-1}{2}\right\rfloor$ or fewer errors, and conversely. An $[n, k]$ linear code with minimum distance $d$ is often called an $[n, k, d]$ code. A quaternary code is a $[n, k, d]$ code over $\mathrm{GF}(4)$. In this paper, we intend to explore the
[5,3,3] linear codes over GF(4). Recall that GF(4) denotes the Galois field of order 4 comprising of $0,1, \omega$ and $\omega$ with the following addition and multiplication tables:

| + | 0 | 1 | $\omega$ | $\omega$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 1 | $\omega$ | $\omega$ |
| 1 | 1 | 0 | $\omega$ | $\omega$ |
| $\omega$ | $\omega$ | $\omega$ | 0 | 1 |
| $\omega$ | $\omega$ | $\omega$ | 1 | 0 |


| $\times$ | 0 | 1 | $\omega$ | $\varnothing$ |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 |
| 1 | 0 | 1 | $\omega$ | $\omega$ |
| $\omega$ | 0 | $\omega$ | $\omega$ | 1 |
| $\omega$ | 0 | $\omega$ | 1 | $\omega$ |

## 2. Existence of a [5,3,3] Linear Code

By singleton bound $d \leq n-k+1$ for an $[n, k, d]$ code. Hence for a $[5,3]$ code, $d=3$ is the maximum attainable minimum distance. On the other hand, to be 1 error correcting, the minimum distance of a linear code should be at least 3 . Hence, an 1 error correcting [5,3] code, if it exists, has to be a [5,3,3] code. In this paper, we will show that there exist no [5,3,3] code over fields of order 2 and order 3 , but there do exist $[5,3,3]$ codes over fields of order 4 or greater.

Theorem 2.1. There exists no [5,3] one error correcting binary code.
Proof. Let $M$ be a generator matrix of a [5,3] binary code. Then

$$
M=\left[\begin{array}{ccccc}
1 & 0 & 0 & a_{11} & a_{12} \\
0 & 1 & 0 & a_{21} & a_{22} \\
0 & 0 & 1 & a_{31} & a_{32}
\end{array}\right]
$$

where $a_{i j} \in \mathrm{GF}(2)$ for each $i$ and $j, 1 \leq i \leq 3,1 \leq j \leq 2$.
If the code is to be error correcting, the minimum distance $d$ should be at least 3 . Hence $a_{i j} \neq 0$ for each $i$ and $j, 1 \leq i \leq 3,1 \leq j \leq 2$. One then obtains the following equivalence diagram where $r_{i}$ and $c_{i}$ denote the $i$ th row and $i$ th column respectively.

$$
\begin{aligned}
M= & {\left[\begin{array}{lllll}
1 & 0 & 0 & a_{11} & a_{12} \\
0 & 1 & 0 & a_{21} & a_{22} \\
0 & 0 & 1 & a_{31} & a_{32}
\end{array}\right] \xrightarrow[a_{11}^{-1} r_{1}, a_{21}^{-1} r_{2}, a_{31}^{-1} r_{3}]{ }\left[\begin{array}{ccccc}
a_{11}^{-1} & 0 & 0 & 1 & a_{11}^{-1} a_{12} \\
0 & a_{21}^{-1} & 0 & 1 & a_{21}^{-1} a_{13} \\
0 & 0 & a_{31}^{-1} & 1 & a_{31}^{-1} a_{14}
\end{array}\right] } \\
& \xrightarrow{a_{11} c_{1}, a_{21} c_{2}, a_{31} c_{3}}\left[\begin{array}{llllll}
1 & 0 & 0 & 1 & a_{11}^{-1} a_{12} \\
0 & 1 & 0 & 1 & a_{21}^{-1} a_{13} \\
0 & 0 & 1 & 1 & a_{31}^{-1} a_{14}
\end{array}\right] \xrightarrow{a=a_{11}^{-1} a_{12}, b=a_{21}^{-1} a_{13}, c=a_{31}^{-1} a_{14}}\left[\begin{array}{ccccc}
1 & 0 & 0 & 1 & a \\
0 & 1 & 0 & 1 & b \\
0 & 0 & 1 & 1 & c
\end{array}\right] \\
& \xrightarrow{a^{-1} c_{5}}\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & a^{-1} b \\
0 & 0 & 1 & 1 & a^{-1} c
\end{array}\right] \xrightarrow{x=a^{-1} b, y=a^{-1} c}\left[\begin{array}{ccccc}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & x \\
0 & 0 & 1 & 1 & y
\end{array}\right]=G .
\end{aligned}
$$

Since code is binary, and each of $x$ and $y$ is nonzero, $x=y=1$. Hence

$$
G=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 1
\end{array}\right]
$$

If we now add the 1 st and 2 nd row vectors of $G$, we get the codeword ( $1,1,0,0,0$ ) which has weight 2 . There therefore exists no error correcting binary [5,3] code.

Theorem 2.2. There exists no [5,3] one error correcting ternary code.
Proof. Let $M$ be a generator matrix of a [5,3] binary code. Then

$$
M=\left[\begin{array}{ccccc}
1 & 0 & 0 & a_{11} & a_{12} \\
0 & 1 & 0 & a_{21} & a_{13} \\
0 & 0 & 1 & a_{31} & a_{14}
\end{array}\right]
$$

where $a_{i j} \in \mathrm{GF}(3)$ for each $i$ and $j, 1 \leq i \leq 3,1 \leq j \leq 2$.
Using the equivalence diagram as in Theorem 2.1 above, we get that $M$ is equivalent to

$$
G=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & x \\
0 & 0 & 1 & 1 & y
\end{array}\right]
$$

where $x y=11,12,21$ or 22 . Thus, we obtain 4 generator matrices from $G$ :

$$
\begin{array}{ll}
G_{1}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 1
\end{array}\right], & G_{2}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & 1 \\
0 & 0 & 1 & 1 & 2
\end{array}\right], \\
G_{3}=\left[\begin{array}{llllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & 2 \\
0 & 0 & 1 & 1 & 1
\end{array}\right], & G_{4}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & 2 \\
0 & 0 & 1 & 1 & 2
\end{array}\right] .
\end{array}
$$

It is an easy exercise to check that each of $G_{i}$ above generates a code, which has a codeword of weight 2 . There exists no [5,3] one error correcting ternary code.

The following theorem shows that there do exist 1-error correcting quaternary [5, 3] codes and they are all equivalent.

Theorem 2.3. An 1-error correcting [5,3] quaternary code is equivalent to the code with the following generator matrix $\bar{G}$ where

$$
\bar{G}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \omega \\
0 & 0 & 1 & 1 & \omega
\end{array}\right]
$$

and 1 and $\omega$ and $\varrho$ are nonzero elements of $\mathrm{GF}(4)$ with 1 representing the identity element.
Proof. Let $M$ be a generator matrix of a 1-error correcting [5,3] quaternary code. Then as in Theorem 2.1 above, $M$ can be shown to be equivalent to

$$
G=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & x \\
0 & 0 & 1 & 1 & y
\end{array}\right]
$$

where $x$ and $y$ are nonzero elements of GF(4). Notice that $x$ cannot be 1 , as then the first two rows of $G$ if added will produce a codeword of weight 2 . On the other hand $x$ and $y$ cannot be
same, as then the last two rows of $G$ if added will give a codeword of weight 2. Hence, we obtain only two codes from $G$ with the following generator matrices:

$$
G_{1}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \omega \\
0 & 0 & 1 & 1 & \omega
\end{array}\right] \quad \text { or } \quad G_{2}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \omega \\
0 & 0 & 1 & 1 & \omega
\end{array}\right]
$$

which could have error correction power.
We now see in the diagram below that $G_{1}$ and $G_{2}$ generate equivalent codes.

$$
G_{1}=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \omega \\
0 & 0 & 1 & 1 & \omega
\end{array}\right] \xrightarrow{\operatorname{swap}\left(r_{1}, r_{2}\right)}\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \omega \\
0 & 0 & 1 & 1 & \omega
\end{array}\right] \xrightarrow{\operatorname{swap}\left(c_{1}, c_{2}\right)}\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & \omega \\
0 & 0 & 1 & 1 & \omega
\end{array}\right]=G_{2} .
$$

Notice that $\bar{G}=G_{1}$.
We now show that the code generated by $\bar{G}$ is able to correct 1 error. Notice that the parity check matrix of $\bar{G}$ is

$$
\bar{H}=\left[\begin{array}{lllll}
1 & 1 & 1 & 1 & 0 \\
1 & \omega & \omega & 0 & 1
\end{array}\right]
$$

and no two columns of $\bar{H}$ are dependent. However, there exist 3 columns of $\bar{H}$

$$
\left[\begin{array}{l}
1 \\
1
\end{array}\right],\left[\begin{array}{l}
1 \\
0
\end{array}\right] \text { and }\left[\begin{array}{l}
0 \\
1
\end{array}\right]
$$

which are dependent. Then by a well-known theorem [1], the minimum weight of the code generated by $\bar{G}$ is 3 .

The next theorem shows that there do always exist an 1-error correcting [5,3] code over GF $(q)$.

Theorem 2.4. Let $\operatorname{GF}(q)$ be a field of order $q$ where $q \geq 4$, then there do always exist $a[5,3,3]$ code over GF $(q)$.

Proof. Let $M$ be a generator matrix of a [5,3] code over $\operatorname{GF}(q), q \geq 4$. Then

$$
M=\left[\begin{array}{ccccc}
1 & 0 & 0 & a_{11} & a_{12} \\
0 & 1 & 0 & a_{21} & a_{13} \\
0 & 0 & 1 & a_{31} & a_{14}
\end{array}\right]
$$

where $a_{i j} \in \operatorname{GF}(q)$ for each $i$ and $j, 1 \leq i \leq 3,1 \leq j \leq 2$.
Using the equivalence diagram as in Theorem 1 above, we get that $M$ is equivalent to

$$
G=\left[\begin{array}{lllll}
1 & 0 & 0 & 1 & 1 \\
0 & 1 & 0 & 1 & x \\
0 & 0 & 1 & 1 & y
\end{array}\right]
$$

Since $q \geq 4$, exist nonzero $x, y \in \mathrm{GF}(q)$ such that $1, x$ and $y$ are all distinct. Then no two columns of

$$
H=\left[\begin{array}{lllll}
1 & 1 & 1 & 1 & 0 \\
0 & x & y & 0 & 1
\end{array}\right]
$$

are dependent and exist 3 columns of $H$

$$
\left[\begin{array}{l}
1 \\
1
\end{array}\right],\left[\begin{array}{l}
1 \\
0
\end{array}\right] \text { and }\left[\begin{array}{l}
0 \\
1
\end{array}\right]
$$

which are dependent. Hence the minimum weight of the code generated by $G$ or $M$ is 3 .
Now a word or two about the weight distribution of the 1-error correcting [5,3] quaternary codes. We have written a MAPLE program to compute the weight distribution of the code generated by $\bar{G}=\left[\begin{array}{lllll}1 & 0 & 0 & 1 & 1 \\ 0 & 1 & 0 & 1 & \omega \\ 0 & 0 & 1 & 1 & \omega\end{array}\right]$ and obtained the following result: $A_{0}=1, A_{3}=30, A_{4}=15$ and $A_{4}=18$, where $A_{i}$ indicates the number of codewords of weight $i$.

## 3. Error-Correcting Devices and the Related Mathematics

An ordered pair of field elements of GF(2) is a Cartesian pair $(a, b) \in \operatorname{GF}(2) \times \mathrm{GF}(2)$, denoted below by $a b$ for the sake of convenience. Obviously there are 4 such pairs, namely $00,01,10$ and 11. We represent the field elements of GF(4) by an ordered pair of field elements of GF(2) as follows:

$$
0 \rightarrow 00,1 \rightarrow 11, \omega \rightarrow 01 \text { and } \omega \rightarrow 10 .
$$

Then the addition and multiplication tables of GF(4), using this representation, assume the following form:

| + | 0 | 11 | 01 | 10 |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | 10 | 11 | 01 | 10 |  | $\times$ | 00 | 11 | 01 |
| 00 | 00 | 00 | 00 | 00 |  |  |  |  |  |
| 11 | 11 | 00 | 10 | 01 |  |  |  |  |  |
|  |  | 11 | 00 | 11 | 01 | 10 |  |  |  |
| 01 | 01 | 10 | 00 | 11 |  | 01 | 00 | 01 | 10 |
| 10 | 10 | 01 | 11 | 00 |  | 10 | 00 | 10 | 11 |
| 10 | 01 |  |  |  |  |  |  |  |  |

One can easily check that if $a_{1} a_{0}+b_{1} b_{0}=f_{1} f_{0}$, then

$$
f_{0}=\left(a_{0} \oplus b_{0}\right) \cdot\left(\overline{a_{1} \oplus b_{1}}\right)+\left(a_{0} \oplus b_{0}\right) \cdot\left(a_{1} \oplus b_{1}\right)
$$

and

$$
f_{1}=\overline{\left(a_{0}+b_{0}\right)} \cdot\left(a_{1}+b_{1}\right)+\left(a_{0}+b_{0}\right) \cdot\left(a_{1} \oplus b_{1}\right) .
$$

Given below is a gate implementation of the addition table of GF(4) that we will call adder and denote by $a d d 2$.


Note that though add 2 adds only 2 elements of GF(2), using recursion, we can build add $a d d i$ for any number of $i$ elements from GF(4).

Similarly, if $a_{1} a_{0} \cdot b_{1} b_{0}=f_{1} f_{0}$, then

$$
f_{0}=\overline{a_{1}} a_{0} b_{1}+a_{1} \overline{a_{0}}\left(b_{1} \oplus b_{0}\right)+a_{1} a_{0} b_{0}
$$

and

$$
f_{1}=\overline{a_{1}} a_{0}\left(b_{1} \oplus b_{0}\right)+a_{1} a_{0} b_{1}+a_{1} a_{0} b_{1}+a_{1} \overline{a_{0}} b_{0}
$$

Given below is a binary logic gate level implementation of the multiplication table of GF(4) that we will call 'multiplier 'denoted by mul.


We will use the adders and multiplier circuits that we designed above to add and multiply the field elements of $\mathrm{GF}(4)$ as we construct below the design of the encoder. Let $C$ be the code generated by $G$ where

$$
G=\left[\begin{array}{lllll}
g_{11} & g_{12} & g_{13} & g_{14} & g_{15} \\
g_{21} & g_{22} & g_{23} & g_{24} & g_{25} \\
g_{31} & g_{32} & g_{33} & g_{34} & g_{35}
\end{array}\right]
$$

Then $C=\left\{x_{0} r_{0}+x_{1} r_{1}+x_{2} r_{2} \mid x_{0}, x_{1}, x_{2} \in \mathrm{GF}(4)\right\}$ where $r_{i}$ indicates the $i$ th row of $G$. The vector $m=\left(x_{0}, x_{1}, x_{2}\right)$ is called the message and $c=\left(y_{0}, y_{1}, y_{2}, y_{3}, y_{4}\right)$ is called the codeword.

We compute the 5 coordinates of the codeword using the following set of 5 equations:

$$
\begin{align*}
& y_{0}=x_{0} g_{11}+x_{1} g_{21}+x_{2} g_{31} \\
& y_{1}=x_{0} g_{12}+x_{1} g_{22}+x_{2} g_{32} \\
& y_{2}=x_{0} g_{13}+x_{1} g_{23}+x_{2} g_{33}  \tag{I}\\
& y_{3}=x_{0} g_{14}+x_{1} g_{24}+x_{2} g_{34} \\
& y_{4}=x_{0} g_{15}+x_{1} g_{25}+x_{2} g_{35}
\end{align*}
$$

Hence, an encoder transforms the message $m=\left(x_{0}, x_{1}, x_{2}\right)$ into a codeword $c=\left(y_{0}, y_{1}, y_{2}, y_{3}, y_{4}\right)$ using the generator matrix $G$. This process of transforming a message $m$ into a codeword $c$ is called an encoding and the device that carries out this transformation is called an encoder. Given below is a circuit diagram that illustrates the encoding process of a message.


It stores three $x$ s of message $m=\left(x_{0}, x_{1}, x_{2}\right)$ into three flip-flops of input register. It also stores the $i$ th column $\left[g_{1 i}, g_{2 i}, g_{3 i}\right]^{\text {transpose }}$ of the generator matrix $G$ in the register $C[i]$ for each $i=0,1, \ldots, 4$. Note that there are 5 circuits, each of which comprises of 3 mul circuits. Of these five, the $i$ th circuit from top, computes $x_{0} g_{1 i}$ in the top mul, $x_{1} g_{1 i}$ in the middle mul and $x_{2} g_{3 i}$ in the bottom mul. The $a d d i$ then adds these $x_{0} g_{1 i}, x_{1} g_{2 i}$ and $x_{2} g_{3 i}$, and yields the $i$ th coordinate $y_{i}$ of the codeword $c$.

Next, we discuss a device, known as syndrome calculator. We begin by explaining the mathematics involved. Let

$$
H=\left[\begin{array}{lllll}
h_{11} & h_{12} & h_{13} & h_{14} & h_{15} \\
h_{21} & h_{22} & h_{23} & h_{24} & h_{25}
\end{array}\right]
$$

be a parity check matrix of the code $C$. Suppose a codeword $c=\left(y_{0}, y_{1}, y_{2}, y_{3}, y_{4}\right)$ is send through the transmission channel and the vector $r=\left(r_{0}, r_{1}, r_{2}, r_{3}, r_{4}\right)$ has been received.

Then the syndrome of $r$, denoted by $s(r)=\left(s_{0}, s_{1}\right)$, is given by:

$$
\begin{aligned}
{\left[\begin{array}{l}
s_{0} \\
s_{1}
\end{array}\right] } & =H r^{\prime}=\left[\begin{array}{lllll}
h_{11} & h_{12} & h_{13} & h_{14} & h_{15} \\
h_{21} & h_{22} & h_{23} & h_{24} & h_{25}
\end{array}\right]\left[\begin{array}{l}
r_{0} \\
r_{1} \\
r_{2} \\
r_{3} \\
r_{4}
\end{array}\right] \\
& =\left[\begin{array}{l}
r_{0} h_{11}+r_{1} h_{12}+r_{2} h_{13}+r_{3} h_{14}+r_{4} h_{15} \\
r_{0} h_{21}+r_{1} h_{22}+r_{2} h_{23}+r_{3} h_{24}+r_{4} h_{25}
\end{array}\right] .
\end{aligned}
$$

Hence, we obtain the following pair of equations:

$$
\left.\begin{array}{r}
r_{0} h_{11}+r_{1} h_{12}+r_{2} h_{13}+r_{3} h_{14}+r_{4} h_{15}  \tag{II}\\
r_{0} h_{21}+r_{1} h_{22}+r_{2} h_{23}+r_{3} h_{24}+r_{4} h_{25}
\end{array}\right\}
$$

The device below computes $s(r)=\left(s_{0}, s_{1}\right)$.


It stores the five $r_{i} \mathrm{~s}$ of $r$ in the five flip-flops of input register. It also stores the five elements $h_{11}, h_{12}, h_{13}, h_{14}, h_{15} \in \mathrm{GF}(4)$ of the first row of the parity check matrix $H$ in the five flip-flops of the register $R[0]$. The five elements $h_{21}, h_{22}, h_{23}, h_{24}, h_{25} \in \mathrm{GF}(4)$ of the second row of $H$ are stored in $R[1]$, which like $R[0]$ comprises of five flip-flops. Notice that there are two blocks, each comprising of five gates, in the right part of the device. The upper block computes $r_{0} h_{11}, r_{1} h_{12}, r_{2} h_{13}, r_{3} h_{14}, r_{4} h_{15}$. These terms are then added by add 5 to produce output $s_{0}$.

Similarly, the lower block computes $r_{0} h_{21}, r_{1} h_{22}, r_{2} h_{23}, r_{3} h_{24}, r_{4} h_{25}$, which are then added by add 5 to output $s_{1}$.

Next, we discuss comparator. A comparator is a device that takes two elements $x$ and $y$ of $\mathrm{GF}(4)$ as inputs and yields 1 if the elements are same and 0 otherwise. If viewed as an ordered pair, $x=a_{1} a_{0}$ and $y=b_{1} b_{0}$, then it is an easy exercise to see that the output $z$ of the comparator is given by $z=\overline{\left(a_{0}+b_{0}\right)} \cdot \cdot \overline{\left(a_{1}+b_{1}\right)}$. Given below is a logic design that implements a comparator. We will need this device when we build the decoder.


Finally, we discuss the decoder. The decoder detects and corrects the error (if any) in the received vector $r$ and outputs the codeword $c$ that was sent through the channel. Suppose we send the codeword $c$. However, due to noise in the transmission channel, an error occurs and the received vector $r$ is different by a single bit from $c$. Then $e=r-c$ is called error vector and has the shape $e=(0, \ldots, 0, \alpha, 0, \ldots, 0)$, where $\alpha \neq 0$ and the coordinate position of $\alpha$ indicates the coordinate position of the bit that was corrupted. To recover the codeword $c$ from the received vector $r$ we first form the parity check matrix $H$ using the basis vectors of $\operatorname{ker}(G)$, where $G$ is the generator matrix of code $C$.

We compute $H r^{t}$ as follows:

$$
\begin{aligned}
H r^{t} & =H(c+(r-c))^{t} \\
& =H(c+e)^{t} \\
& =H c^{t}+H e^{t}
\end{aligned}
$$

Since $c \in \operatorname{ker} H, H c^{t}=\left[\begin{array}{l}0 \\ 0\end{array}\right]$.
Since $e=(0, \ldots, 0, \alpha, 0, \ldots, 0), H e^{t}=\alpha$. a column of $H$. Hence $H r^{t}=\alpha$. a column of $H r^{t}=\alpha \cdot j$ th. If $H$ column of $H$ where $j \in\{1,2,3,4,5\}$ and $\alpha \in \mathrm{GF}(4)$ such that $\alpha \neq 0$, then the error has occurred in the $j$ th bit of the sent code-word and the error vector $e$ has field element $\alpha$ in its $j$ th coordinate position and zeros in others i.e. $e=(0,0, \ldots, \alpha, \ldots, 0,0)$ where $\alpha$ is the $j$ th bit of $e$. If $H r^{t}$ is zero vector, no error has occurred during transmission. We compute $r-e$ to recover the codeword $c$.

Given in the next page is a circuit design of the decoder. The received vector $r=$ $\left(r_{0}, r_{1}, r_{2}, r_{3}, r_{4}\right)$ is stored in the five flip-flops of the input register. The register $N$ comprises of three flip-flops which contain $1, \omega$ and $\varphi$. On the other hand, register $C[i]$ comprises if 2 flip-flops, which contains the 2 elements of the $i$ th column $\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}$ of the parity check matrix $H$. Notice that there are 3 pairs of mul circuits adjacent to and at a level of $C[i]$. The top pair multiplies [ $\left.h_{1 i} h_{2 i}\right]^{\text {transposed }}$ with 1 , the middle pair with $\omega$ and the bottom pair with $\omega$
respectively. Now notice that there are also 3 pairs of comparators next to these mul circuits at their level. The top comparator pair compares $1 \cdot\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}$ with $\left[s_{0} s_{1}\right]^{\text {transposed }}$, the middle pair compares $\omega \cdot\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}$ with $\left[s_{0} s_{1}\right]^{\text {transposed }}$ and the bottom pair compares $\omega \cdot\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}$ with $\left[s_{0} s_{1}\right]^{\text {transposed }}$.


Journal of Informatics and Mathematical Sciences, Vol. 7, No. 1, pp. 1-11, 2015

Three cases arise here:
(1) If $1 \cdot\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}=\left[\begin{array}{ll}s_{0} & s_{1}\end{array}\right]^{\text {transposed }}$, then 1 enters into the add 4 from the topmost pair of "and" gates, whereas from the other two pairs of the "and" gates 2 zeros enter into add 4. The add 4 then adds $1,0,0, r_{i}$ and yields the $i$ th coordinate of the transmitted codeword $c$.
(2) If $\omega \cdot\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}=\left[s_{0} s_{1}\right]^{\text {transposed }}$, then $\omega$ enters into the $a d d 4$ from the middle pair of "and" gates, whereas from the other two pairs of the "and" gates 2 zeros enter into add 4. The add 4 then adds $\omega, 0,0, r_{i}$ and yields the $i$ th coordinate of the transmitted codeword $c$.
(3) Finally if $\omega \cdot\left[h_{1 i} h_{2 i}\right]^{\text {transposed }}=\left[s_{0} s_{1}\right]^{\text {transposed }}$, then $\infty$ enters into the $a d d 4$ from the middle pair of "and" gates, whereas from the other two pairs of the "and" gates 2 zeros enter into $a d d 4$. The $a d d 4$ then adds $\oplus, 0,0, r_{i}$ and yields the $i$ th coordinate of the transmitted codeword $c$.

## 4. Conclusion

In this study, we have established that the field of the lowest order over which there exists an 1-error correcting [5,3] code is a quaternary field. We also found that there exists only one distinct [ $5,3,3$ ] quaternary code up to equivalence. This code is capable of 1-error correction in 64 distinct codewords. We devised a method to implement this quaternary 1-error correcting code in a binary data transmission system. We have simulated the designs of the encoder and the decoder using 'MODELSIM' synthesized the logics using 'XILINX' and found the devices working correctly. We wish to analyze the efficiency and other characteristics of this code and related circuit designs in a different study.

## Competing Interests

The authors declare that they have no competing interests.

## Authors' Contributions

All the authors contributed equally and significantly in writing this article. All the authors read and approved the final manuscript.

## References

[^0]
[^0]:    ${ }^{[1]}$ V. Pless (2003), Introduction to the Theory of Error Correcting Codes, Wiley; Student Edition, John Wiley \& Sons (Asia) Pte. Ltd., Singapore.
    ${ }^{[2]}$ R. Hill (1986), A First Course in Coding Theory, The Oxford University Press, Oxford, UK.
    ${ }^{[3]}$ W.C. Huffman and V. Pless (2003), Fundamentals of Error Correcting Codes, Cambridge University Press, New York.

