# Reed Solomon Codes for Reliable Communication in Internet of Things (IOT) 

Ali Mahmudi*<br>Software Engineering Dept, National Institute of Technology (ITN)<br>Malang, Indonesia


#### Abstract

In the networking field, Internet of Things ( IOT, shortly) is the current state of the art in the nowadays Information of Technology era. The networking may be defined as external network or internal network. The backbone of the IOT is the internet connections. The IOT connects various objects together to the internet so that they can communicate and exchange billions of data and information among various devices and services. They may be remotely controlled from distant area. As IOT systems will be open and available everywhere, a number of security issue may arise. One issue that remains open in the IOT technology is security and privacy issues. Because of this security issue, the communications among many different devices powered by IOT could not be said as a reliable technology.

Because of this, the security of the IOT systems can be enhanced by adding error correction scheme both in communication channel as well as the data store. By introducing the error correction scheme, the risks may be reduced to acceptable level and the security could be enhanced. A Reed-Solomon (RS) code is one of many error control coding schemes that firstly introduced by Reed and Solomon in 1960. This code has been used in various applications, such as CD-ROMs, space communications, DVD technology, digital TV and much more.

Here, Reed-Solomon code is discussed in detail. It raised the issue of RS decoding scheme using the Welch Berlekamp algorithm. It presents the implementation of the Welch Berlekamp algorithm for RS decoder in detail. The VHDL implementation VHDL for Hard Decision Decoding using the Welch Berlekamp algorithm is also presented. Without loss of generality, the


[^0]Hard Decision Decoding for $\operatorname{RS}(255,239)$ over $\operatorname{GF}\left(2^{8}\right)$ is developed using VHDL.

Keywords: Internet of Things, IOT, error control codes, Reed Solomon Codes, VHDL

## 1. Introduction

Internet of Things was firstly introduced by Kevin Ashton in 1999. Since 15 years ago, there is not yet a global consensus on the definition of IoT. In general, the IOT is defined as the ability to connect various different objects together using internet connection as the backbone, and allows them to interact with other objects, or with other intelligent computing equipment via the internet network. IOT has been used in various applications in many aspects of human life. [1]

Widespread use of IOT technology in modern life, making human life becomes much more comfortable. IOT has affected nowadays human life, from the domestic home appliances up to smart cars. In business point of view, IOT has been used in decision making to increase production as well quality of production, to oversee the distribution of goods, to prevent counterfeiting, to shorten the waiting time of unavailability goods in retail markets, in supply chain management, and so on.

IOT has also been used in public health sector. IoT has been used in medical applications, for example, for monitoring glucose in a diabetic patient. A doctor can receive data in real time, to monitor the patient's condition and to manage the medicine of a patient from home by using IOT application as a backbone. Thus, looking after and monitoring a patient becomes much easier to do. IOT has also been adopted in smart home applications, which makes it possible to arrange and control some home appliances remotely from a distant area. [1]

IOT consists of different devices. Some technology involved are RFID as an object and location identifier, WSN or Wireless Sensor Network, cloud computing and so on. They are connected with various data collection terminals through internet networks and other communication networks. Data about an object is taken in real time, it is then converted into the appropriate data format and then sent to the data center. Data is then processed using cloud computing and other intelligent computing technology that can process and store large amounts of data. [2]

As many technologies involved in building up IoT, a reliable data communication system is needed to protect every part of the data. Broadly speaking, there are three things that may become an issue. The first is physical security, especially the security of sensors and RFID from interference, and signal interception. Second is that all of those elements, such as sensors, transmission systems and others, should operate normally. The system should guarantee that all those elements should work as they should be. The last one is reliable data and information exchange. The message
transmission between devices in IOT should be more reliable, authentication, integrity and confidentiality. The data and information sent and received along the internet network should not be damaged, stolen or falsified. [3]

Because of this, the reliability of the IOT systems can be enhanced by adding error correction scheme both in communication channel as well as the data store. By introducing the error correction scheme, the risks may be reduced to acceptable level and the reliability could be enhanced. Reed-Solomon (RS) code is one of many error control coding schemes available. It was firstly introduced by Reed and Solomon in 1960. This code has been used in various applications, such as CD-ROMs, space communications, DVD technology, digital TV and much more.

## 2. Error Control Codes

The general idea behind error control coding is to put some restrictions on the characteristic of the source signals so that the transmitted signals are more immune to corruption. Therefore the effects of noise during transmission are reduced or even eliminated. The term of coding refers to error detection and error correction techniques. Hence, the work of error control coding involves a technique by which some extra information is added to the message signal in such a way that it allows the receiver to estimate the transmitted data from the corrupted received information. This extra information is used to shield the message signals.

The work of coding was pioneered by Shannon in 1948 [4]. He showed that the existence of error control codes would reduce the existence of data corruption in the channel, if data is transmitted at a rate less than the channel capacity. ReedSolomon (RS) codes, developed by Irving Reed and Gus Solomon in 1960 [5], are a type of error control code which have proved to be of practical value in a variety of applications ranging from satellite communications to the recording of information on a storage device [6][7][8][9][10].


Figure 1. The Digital Communication system.
A typical data communication system is shown in Figure 1. The RS encoder takes a block of digital data and then adds extra 'redundant' bits. Errors may occur during transmission or storage for a number of reasons, for example cross talk on a telephone line, scratches on a CD, etc. The RS decoder processes each block and
attempts to correct errors and recover the original data. The number and type of errors that can be corrected depends on the characteristics of the RS code.

RS code is specified as $\operatorname{RS}(n, k)$ over $\operatorname{GF}\left(2^{m}\right)$ with $m$ bits per symbol. This means that
$n(=2 m-1)$ is the number of symbols in every codeword
$k(=n-2 t)$ is the number of information symbols in every codeword
If $t$ is the maximum number of symbols that can be corrected
$d(=2 t+1)$ is the designed distance
$2 t(=n-k)$ is the number of parity check symbols
then the RS code is shown in Figure 2.

| Data $=k$ symbols | Parity $=n-k$ symbols |
| :--- | :--- |

Figure 2. The systematic RS code.
The RS encoder works by taking $k$ data symbols of $m$ bits each and adds $n-k$ parity symbols to make an $n$ symbol codeword. If the information symbol is left unaltered and the parity symbols are appended (as shown in Figure 2), this is called a systematic encoder. It is different from a non-systematic encoder where the information symbols have been altered in such a way that the information symbols are not obvious [11][12]. This non-systematic encoder is not covered in this chapter. The amount of processing required to encode and decode RS codes depends on the number of symbols that can be corrected. A large value of $t$ means that a large number of errors can be corrected but it requires more computation and more hardware than a small value of $t$.

## 3. RS Encoder

The $\operatorname{RS}(n, k)$ code of block length $n$, message length $k$ and designed distance $n-k+1$, is easily explained by using its special polynomial, called generator polynomial, $g(x)$. The general form of the $\operatorname{RS}(n, k)$ generator polynomial is shown in equation (1) [13][14][15].

$$
\begin{equation*}
g(x)=\prod_{i=0}^{n-k-1}\left(x-\alpha^{b+i}\right) \tag{1}
\end{equation*}
$$

where $b$ is a non negative integer selected by the designer. Without loss of generality, it is assumed that $b=0$.

All valid $\operatorname{RS}(n, k)$ codewords can be regarded as being polynomials of degree $(n-1)$ over $\mathrm{GF}\left(2^{\mathrm{m}}\right)$ which are divisible by its generator polynomial $g(\mathrm{x})$. Let

$$
\begin{equation*}
I(x)=i_{0}+i_{1} x+\ldots+i_{k-1} x^{k-1} \tag{2}
\end{equation*}
$$

be the information polynomial to be encoded. The systematic encoding can be considered as multiplying the information polynomial $I(x)$ by $x^{n-k}$ and then follows by dividing the result with $g(x)$ to obtain the remainder polynomial of degree $n-k$ 1. The encoded signal is then formed by subtracting $r(x)$ from $I(x) x^{n-k}$. It can be written as equation (3) [13][16][17]

$$
\begin{equation*}
c(x)=I(x) \cdot x^{n-k}+\left(I(x) \cdot x^{n-k} \bmod g(x)\right) \tag{3}
\end{equation*}
$$

It should be noted that the remainder polynomial is in fact the parity check polynomial. This process ensures that a valid codeword $c(x)$ is a multiple of $g(x)$. The information symbol appears explicitly at the $k$ highest order coefficients and the parity check symbols at the $n-k$ lowest order coefficients. From this fact, it can be seen that the process of encoding is basically carrying out division over a finite field $\mathrm{GF}\left(2^{m}\right)$.

For example, if $g(x)=1+x+x^{3}$ and $I(x)=b_{0}+b_{1} x+b_{2} x^{2}$. Multiplying $I(x)$ by $x^{3}$ will result $b_{0} x^{3}+b_{1} x^{4}+b_{2} x^{5}$. If this result is divided by $g(x)$, then a quotient $\left(b_{0}+b_{2}\right)+b_{1} x+b_{2} x^{2}$ and a remainder $\left(b_{0}+b_{2}\right)+\left(b_{0}+b_{1}+b_{2}\right) x+\left(b_{1}+b_{2}\right) x^{2}$. A circuit, which implements this computation, is shown in Figure 3 [4][12].


Figure 3. The structure of RS encoder over GF(2).

| Shift 0$).$ | $R_{0}=0$ | $R_{1}=0$ | $R_{2}=0$ |
| :--- | :--- | :--- | :--- |
| Shift 1). | $R_{0}=b_{2}$ | $R_{1}=b_{2}$ | $R_{2}=0$ |
| Shift 2). | $R_{0}=b_{1}$ | $R_{1}=b_{1}+b_{2}$ | $R_{2}=b_{2}$ |
| Shift 3). | $R_{0}=b_{0}+b_{2}$ | $R_{1}=b_{0}+b_{1}+b_{2}$ | $R_{2}=b_{1}+b_{2}$ |

The circuit in Figure 3 is very simple because it operates over GF(2) only. In general case of a code defined over $\operatorname{GF}\left(2^{\mathrm{m}}\right)$, multiplication over $\mathrm{GF}\left(2^{\mathrm{m}}\right)$ must also be performed. This generalised encoding scheme is shown in Figure 4[13][15].


Figure 4. The structure of RS encoder over GF $\left(2^{\mathrm{m}}\right)$.

## 4. RS DECODER

In this section, the decoding method of RS codes is considered. The decoding process can be generally classified into two categories, hard decision decoding (HDD) algorithm and soft decision decoding (SDD) algorithm. HDD algorithms include frequency domain decoding and time domain decoding [12][18][19]. Frequency domain decoding begins with the calculation of the syndromes, which is the finite field equivalent of a Discrete Fourier Transform (DFT) [18]. However, in time domain decoding there is no calculation of the syndromes.

There are quite a few algorithms to decode the RS codes, such as the Euclidean algorithm [20][21][22], the Fitzpatrick algorithm [23][24], the Berlekamp Massey (BM) algorithm [25] and the Welch Berlekamp (WB) algorithm[26]. Here, the WB algorithm developed by L. Welch and E.R. Berlekamp, is considered. Many researchers have commented and investigated this algorithm, as can be seen in [22] [27][28][29][30][31][32]. This decoding method does not involve syndrome computation as a starting point. As in [30], this scheme may be used to develop the GMD decoder, one of the many approaches to apply soft decision decoding.

## 5. RS DECODING USING THE WB ALGORITHM

The WB algorithm performs RS decoding without explicit syndrome computation. Furthermore, the WB algorithm is known to be more amenable to SDD which offers around 2 dB more coding gain than HDD [14]. Here, the WB algorithm for decoding RS code is presented [26][30]. The algorithm of decoding RS codes can be broken down into 4 stages as shown in Figure 5:

Stage 1: Re-encoding.
Stage 2: Solving the key equation using the Welch-Berlekamp Algorithm.
Stage 3: Applying the Chien search to solve the error locator polynomial.

Stage 4: Evaluating the error value to obtain the corrected message.


Figure 5. The RS decoder using the WB algorithm.

The first stage of decoding is re-encoding the received input signal $v(x)$. It corresponds to the syndrome computation in conventional RS decoding[30]. Basically, this process is quite similar to the encoding process. Re-encoding takes received information signals and then internally generates $2 t$ parity check signals. If $r^{\prime}(x)$ represents the internally generated parity check signals, then the re-encoding output will be the mod 2 addition of $r^{\prime}{ }_{i}$ and the parity check input, $v_{i}$. This reencoding output is called remainder polynomial $r(x)$. It can be expressed as equation (4) and (5) and the re-encoder circuitry with generator polynomial $g(x)$ as in (1) is shown on Figure 6.

$$
\begin{gather*}
r_{i}=\left\{\begin{array}{c}
0: n-1 \geq i \geq 2 t \\
v_{i}+r_{i}^{\prime}: i<2 t
\end{array}\right.  \tag{4}\\
r(x)=\sum_{i=0}^{2 t-1} r_{i} x^{i} \tag{5}
\end{gather*}
$$



Ali Mahmudi

Figure 6. The re-encoder circuitry.

Let

$$
\begin{equation*}
g^{\prime}(x)=\prod_{i=0}^{2 t-2}\left(x-\alpha^{i}\right) \tag{6}
\end{equation*}
$$

and then equation (7) is pre-computed constants held in memory.

$$
\begin{equation*}
G(x)=\sum_{i=0}^{2 t-1} G_{i} x^{i}=\sum_{i=0}^{2 t-1} \frac{1}{g_{i}^{\prime}} x^{i} \tag{7}
\end{equation*}
$$

Then, $R_{i}$ is computed to get the Welch-Berlekamp input [30] as expressed in equation (8).

$$
\begin{equation*}
R_{i}=r_{i} G_{i} \tag{8}
\end{equation*}
$$

for $i=0,1, \ldots, 2 t-1$.
Then, the Welch Berlekamp algorithm is used to solve the key equation. Let the input to WB algorithm be $2 t$ pairs of $\left(R_{k}, \alpha_{k}\right)$ where $R_{k}$ corresponds to the parity check input and $\alpha_{k}$ ( $=\alpha^{k}$, for the case of error only decoding) corresponds to the check location. As in [26][27][30], the WB algorithm is presented in this section.

For two polynomials $Q(x)$ and $N(x)$ define $L[Q(x), N(x)]$ as the length of the pair, which is the higher value between the degree of $Q(x)$ and degree of $N(x)+1$ [27]. A similar approach is applicable to both $W(x)$ and $V(x)$ polynomials and its corresponding $L[W(x), V(x)]$.

At the iteration number $p$ (where $0<p<2 t$ ), there are two pairs of polynomials [ $\left.Q_{\mathrm{p}}(x), N_{\mathrm{p}}(x)\right]$ and $\left[W_{\mathrm{p}}(x), V_{\mathrm{p}}(x)\right]$ which already fits the already processed checks in equations (9) and (10).

$$
\begin{align*}
& Q^{p}\left(\alpha_{p-1}\right) R_{p-1}=N^{p}\left(\alpha_{p-1}\right)  \tag{9}\\
& W^{p}\left(\alpha_{p-1}\right) R_{p-1}=V^{p}\left(\alpha_{p-1}\right) \tag{10}
\end{align*}
$$

Furthermore, $L[Q(x), N(x)]$ is less than $L[W(x), V(x)]$. The algorithm needs to be extended from $p$ to $p+1$.

At first, the pair of polynomials $\left[Q^{\mathrm{p}}(x), N^{\mathrm{p}}(x)\right]$ needs to be checked if it can accommodate the new input pair. The way to do it is by computing D1 as shown in equation (11)

$$
\begin{equation*}
D 1=Q^{p}\left(\alpha_{p+1}\right) R_{p+1}-N^{p}\left(\alpha_{p+1}\right) \tag{11}
\end{equation*}
$$

If $D 1=0$, it means that $\left[Q^{\mathrm{p}}(x), N^{\mathrm{p}}(x)\right]$ can accommodate the new input pair $\left(R_{\mathrm{p}+1}, \alpha_{\mathrm{p}+1}\right)$ and then branch A of Figure 7 is taken. However, if $D 1$ is not zero, then $D 2$ needs to be computed as shown in equation (12).

$$
\begin{equation*}
D 2=W^{p}\left(\alpha_{p+1}\right) R_{p+1}-V^{p}\left(\alpha_{p+1}\right) \tag{12}
\end{equation*}
$$

Then, the two pairs $\left[Q^{\mathrm{p}}(x), N^{\mathrm{p}}(x)\right]$ and $\left[W^{\mathrm{p}}(x), V^{\mathrm{p}}(x)\right]$ need to be updated. The first updated pair is the $(W, V)^{\mathrm{p}+1}$ polynomials as shown in equation (13)

$$
\begin{equation*}
(W, V)^{p+1}=(W, V)^{p}+D 2(Q, N)^{p} / D 1 \tag{13}
\end{equation*}
$$

and the second pair is the $(Q, N)^{\mathrm{p}+1}$ polymoails as shown in equation (14)

$$
\begin{equation*}
(Q, N)^{p+1}=(Q, N)^{p}\left(x-\alpha_{p+1}\right) \tag{14}
\end{equation*}
$$

Finally, the orders of the two updated pairs need to be compared. The shorter value between equations (13) and (14) is set to be $\left[Q^{\mathrm{p}+1}(x), N^{\mathrm{p}^{+1}}(x)\right]$, and the longer one is set to be $\left[W^{\mathrm{p}+1}(x), V^{\mathrm{p}+1}(x)\right]$. In other words, if the shorter polynomial pair is given by equation (14), then branch $B$ of Figure 7 is taken. However, if the shorter polynomial pair is given by equation (13), then branch $C$ is taken.

The WB algorithm process is carried out until all the $2 t$ check pairs have been processed. Once all the $2 t$ check pairs have been processed, the final value of both $Q(x)$ and $N(x)$ polynomials are taken for further process. The $Q(x)$ polynomial represents the error locator polynomial, and its roots need to be found. The Chien search method [33] is used to solve the $Q(x)$ polynomial. Let $Q(x)$ be a polynomial of degree $p$ (where $p \leq t$ ) as shown in equation (15).

$$
\begin{equation*}
Q(x)=q_{p} x^{p}+q_{p-1} x^{p-1}+\ldots+q_{0} \tag{15}
\end{equation*}
$$



Figure 7. The WB algorithm Flow Chart Diagram.

If $Q_{1}(x)=q_{1} x^{1}$ for $0<l \leq p$, then equation (16) applies

$$
\begin{equation*}
Q(x)=Q_{p}(x)+Q_{p-1}(x)+\ldots+q_{0} \tag{16}
\end{equation*}
$$

and the equation (16) can be shown as equation (17).

$$
\begin{equation*}
Q\left(\alpha^{x}\right)=Q_{p}\left(\alpha^{x+1}\right) \alpha^{-p}+Q_{p-1}\left(\alpha^{x+1}\right) \alpha^{1-p}+\ldots+q_{0} \tag{17}
\end{equation*}
$$

The implementation of equation (17) above requires $p$ multipliers. As the $Q^{2 t}(x)$ polynomial will be of order up to $t$, it requires $t$ multipliers.

In order to find the error value, more pre-computed constants are required [30]. Let

$$
\begin{equation*}
C=\left[\left(\alpha^{0} \alpha^{1} \ldots \alpha^{2 t-2}\right)\left(\alpha^{0}-\alpha^{1}\right) \ldots\left(\alpha^{0}-\alpha^{2 t-1}\right)\right]^{-1} \tag{18}
\end{equation*}
$$

and the $C$ value is pre-computed. Then, the $C$ value is multiplied by the generator polynomial $g(x)$ as shown in equation (19).

$$
\begin{equation*}
f(x)=C g(x) \tag{19}
\end{equation*}
$$

The $f(x)$ polynomial is a pre-computed constants held in memory. This $f(x)$ value is solved using a method shown in (17). It requires $2 t$ multipliers.

Once the WB algorithm has been completed, it is followed by the error correction and error evaluation. There are two possible error positions. The first case is error occurred at a data location and its value is obtained using equation (20) below. Where $Q^{\prime}(x)$ polynomial is the derivative of $Q(x)$ polynomial.

$$
\begin{equation*}
e_{i}=\frac{N\left(\alpha^{i}\right)}{f\left(\alpha^{i}\right) Q^{\prime}\left(\alpha^{i}\right)} \tag{20}
\end{equation*}
$$

The second case is error occurred at a check location. The error value at the check location can be found using equation (21) below.

$$
\begin{equation*}
e_{i}=\frac{N\left(\alpha^{i}\right)}{f\left(\alpha^{i}\right) Q^{\prime}\left(\alpha^{i}\right)}+v_{i}, \text { where } v_{i} \text { is the received data. } \tag{21}
\end{equation*}
$$

Alternatively, it could be corrected by re-encoding the error-free information signal or not to be corrected at all.

## 6. RS MODIFIED WB ALGORITHM

Consider the $\operatorname{RS}(n, k)$ decoder with minimum distance $d$, error correcting capabilities $t$ operating over $\operatorname{GF}\left(2^{\mathrm{m}}\right)$. Let the input to the WB algorithm be 2 t check pairs $\left(R_{k}, \alpha_{k}\right)$ where $R_{k}$ and $\alpha_{k}$ represent the check value and check location respectively. The modified version of the WB algorithm is shown in Figure 8, which is a modified version of the one given in [30][34]. This modification will be discussed in detail.

The most obvious difference is the use of J control signal instead of $L[Q(x)$, $N(x)]$ and $L[W(x), V(x)]$. Let $L[Q(x), N(x)]$ is defined to be the higher value between the order of $Q(x)$ polynomial and the order of $N(x)+1$ polynomial. Similarly applies to $L[W(x), V(x)]$, which is defined as the higher value between the order $W(x)$ and order $V(x)+1$. The reason for this is explained as follows.

Let

$$
\begin{equation*}
J^{k}=L\left[W^{k}(x), V^{k}(x)\right]-L\left[Q^{k}(x), N^{k}(x)\right] \tag{22}
\end{equation*}
$$

The cycle enters branch $A$ if $D 1=0$ (see Figure 7). At this branch, both $W(x)$ and $V(x)$ polynomials are multiplied by $\left(x-\alpha_{\mathrm{k}}\right)$, on the other hand the $Q(x)$ and $N(x)$ polynomials remain unchanged. So, the degrees of both updated $W(x)$ and $V(x)$ polynomials are incremented by one, however the orders of the updated $Q(x)$ and $N(x)$ polynomials remain unchanged. It is then expressed in mathematical terms as (23) and (24).

$$
\begin{gather*}
L\left[W^{k+1}(x), V^{k+1}(x)\right]=L\left[W^{k}(x), V^{k}(x)\right]+1  \tag{23}\\
L\left[Q^{k+1}(x), N^{k+1}(x)\right]=L\left[Q^{k}(x), N^{k}(x)\right] \tag{24}
\end{gather*}
$$

So applying equation (22) to both equations (23) and (24) yields equation (25).

$$
\begin{equation*}
J^{k+1}=J^{k}+1 \tag{25}
\end{equation*}
$$



Figure 8. The modified WB algorithm flow chart diagram.

Branch $B$ is taken if $D 1 \neq 0$ and $L\left[Q^{\mathrm{k}}(x), N^{\mathrm{k}}(x)\right]+1 \leq L\left[V^{\mathrm{k}}(x), \nu^{\mathrm{k}}(x)\right]$ (see Figure 7). In this branch, both the $Q(\mathrm{x})$ and $N(x)$ polynomials are multiplied by ( $x-\alpha_{\mathrm{k}}$ ), therefore the updated degree of $Q(x)$ (and $N(x)$, if applicable) would be incremented
by one. On the other hand, the $W(x)$ and $V(x)$ polynomials are added with $(D 2 / D 1) \cdot Q(x)$ and $(D 2 / D 1) \cdot N(x)$, consecutively. The order of both $(W(x), V(x))$ polynomials does not change at all because of the condition $L\left[Q^{\mathrm{k}}(x), N^{\mathrm{k}}(x)\right]+1 \leq$ $L\left[W^{\mathrm{k}}(x), V^{\mathrm{k}}(x)\right]$. In mathematical terms, it can be expressed as equations (26) and (27)

$$
\begin{gather*}
L\left[W^{k+1}(x), V^{k+1}(x)\right]=L\left[W^{k}(x), V^{k}(x)\right]  \tag{26}\\
L\left[Q^{k+1}(x), N^{k+1}(x)\right]=L\left[Q^{k}(x), N^{k}(x)\right]+1 \tag{27}
\end{gather*}
$$

Then, applying equation (22) to both equations (26) and (27) yields (28)

$$
\begin{equation*}
J^{k+1}=J^{k}-1 \tag{28}
\end{equation*}
$$

If $D 1 \neq 0$ and $L\left[Q^{\mathrm{k}}(x), N^{\mathrm{k}}(x)\right]+1>L\left[W^{\mathrm{k}}(x), V^{\mathrm{k}}(x)\right]$, the process enters branch C (see Figure 7). The condition as in (29) can be rewritten as equation (30)

$$
\begin{align*}
& L\left[Q^{k}(x), N^{k}(x)\right]+1>L\left[W^{k}(x), V^{k}(x)\right]  \tag{29}\\
& L\left[W^{k}(x), V^{k}(x)\right]-L\left[Q^{k}(x), N^{k}(x)\right]<1 \tag{30}
\end{align*}
$$

As $L\left[Q^{\mathrm{k}}(x), N^{\mathrm{k}}(x)\right]$ is never more than $L\left[W^{\mathrm{k}}(x), V^{\mathrm{k}}(x)\right]$ at any value of $k$, then equation (30) could be written as (31) or (32)

$$
\begin{gather*}
L\left[W^{k}(x), V^{k}(x)\right]-L\left[Q^{k}(x), N^{k}(x)\right]=0  \tag{31}\\
J^{k}=0 \tag{32}
\end{gather*}
$$

Then, the control signal to enter either branch $B$ or branch $C$ is modified to checking whether $J^{\mathrm{k}}=0$ or not. The process at branch $C$ generates equation (33), which can be written as equation (34), and equation (35).

$$
\begin{gather*}
L\left[Q^{k+1}(x), N^{k+1}(x)\right]=L\left[W^{k}(x), V^{k}(x)\right]  \tag{33}\\
L\left[Q^{k+1}(x), N^{k+1}(x)\right]=L\left[Q^{k}(x), N^{k}(x)\right]  \tag{34}\\
L\left[W^{k+1}(x), V^{k+1}(x)\right]=L\left[Q^{k}(x), N^{k}(x)\right]+1 \tag{35}
\end{gather*}
$$

Considering equation (22) to both equations (34) and (35), then it generates equation (36).

$$
\begin{equation*}
J^{k+1}=J^{k}+1 \tag{36}
\end{equation*}
$$

It can be written as (37)

$$
\begin{equation*}
J^{k+1}=1 \tag{37}
\end{equation*}
$$

The other improvement is the calculation of intermediary stage ( $W^{\mathrm{mmp}}, V^{\mathrm{tmp}}$ ) and $\left(Q^{\mathrm{mpp}}, N^{\mathrm{tmp}}\right)$ if $D 1 \neq 0$ as in Figure 8. This calculation may save hardware requirements to implement the WB algorithm and also to make the implementation easier.

## 7. The Implementation of the WB algorithm

Assume that the WB algorithm operates over $\mathrm{GF}\left(2^{8}\right)$. The input check pair is ( $R_{\mathrm{k}}, \alpha_{\mathrm{k}}$ ) where $R_{\mathrm{k}}$ corresponds to the parity check value and $\alpha_{\mathrm{k}}$ corresponds to the check location. In the case of HDD, $\alpha_{k}=\alpha^{k}$. Here, four clock cycles are required to process every check pair. The first clock cycle is to compute the $D 1$ value, the second cycle is to compute both $D 2$ and $D 2 / D 1$ values, the third one is to compute the $\left(Q^{\operatorname{tmp}}(\mathrm{x}), N^{t m p}(x)\right)$ polynomials and finally, the fourth cycle is to calculate the $\left(W^{\mathrm{mp}}(x), V^{\mathrm{tmp}}(x)\right)$ polynomials and to decide which pair become the $Q^{\mathrm{k}+1}(x)$ and $N^{\mathrm{k}+1}(x)$ polynomials and which pair become $W^{\mathrm{k}+1}(x)$ and $V^{\mathrm{k}+1}(x)$ polynomials.

### 7.1. D1 Calculation

As the error correcting capability of the decoder is 8 , the maximum degree of $Q(x)$ and $N(x)$ polynomials are 8 and 7 respectively. Assume that $\alpha_{k}{ }^{2}, \alpha_{k}{ }^{3}, \ldots, \alpha_{k}{ }^{8}$ are already available (see section 6.5 later). To obtain the $Q^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ value, 8 Berlekamp multipliers are required as (38).

$$
\begin{equation*}
Q^{k}\left(\alpha_{k}\right)=Q_{8}^{k} \cdot\left(\alpha_{k}^{8}\right)+Q_{7}^{k} \cdot\left(\alpha_{k}^{7}\right)+Q_{6}^{k} \cdot\left(\alpha_{k}^{6}\right)+\mathrm{K}+Q_{0}^{k} \tag{38}
\end{equation*}
$$

Similarly, the implementation of $N^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ calculation would require 7 multipliers as shown in (39).

$$
\begin{equation*}
N^{k}\left(\alpha_{k}\right)=N_{7}^{k} \cdot\left(\alpha_{k}^{7}\right)+N_{6}^{k} \cdot\left(\alpha_{k}^{6}\right)+N_{5}^{k} \cdot\left(\alpha_{k}^{5}\right)+\mathrm{K}+N_{0}^{k} \tag{39}
\end{equation*}
$$

Once both $Q^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ and $N^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ values are available, $D 1$ can be easily calculated by implementing equation (40)

$$
\begin{equation*}
D 1=Q^{k}\left(\alpha_{k}\right) R_{k}-N^{k}\left(\alpha_{k}\right) \tag{40}
\end{equation*}
$$

and $1 / D 1$ can be easily obtained.

### 7.2. D2 Calculation

As with the $D 1$ calculation, the error correcting capabilities of the decoder is 8 . Hence, the maximum degree of both $W(x)$ and $V(x)$ polynomials are 8 and 7 , respectively. It is assumed that $\alpha_{k}{ }^{2}, \alpha_{k}{ }^{3}, \ldots, \alpha_{k}{ }^{8}$ are already available (see section 6.5 later). The multipliers used in $D 1$ calculation in section 6.1 are re-used in this stage to implement equation (41).

$$
\begin{equation*}
W^{k}\left(\alpha_{k}\right)=W_{8}^{k} \cdot\left(\alpha_{k}^{8}\right)+W_{7}^{k} \cdot\left(\alpha_{k}^{7}\right)+W_{6}^{k} \cdot\left(\alpha_{k}^{6}\right)+\mathrm{K}+W_{0}^{k} \tag{41}
\end{equation*}
$$

Therefore 8 Berlekamp multipliers are required to compute the $W^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ value. Similarly, the implementation of $V^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ calculations would require 7 multipliers as in (42).

$$
\begin{equation*}
V^{k}\left(\alpha_{k}\right)=V_{7}^{k} \cdot\left(\alpha_{k}^{7}\right)+V_{6}^{k} \cdot\left(\alpha_{k}^{6}\right)+V_{5}^{k} \cdot\left(\alpha_{k}^{5}\right)+\mathrm{K}+V_{0}^{k} \tag{42}
\end{equation*}
$$

Once both $W^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ and $V^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ values are available, $D 2$ can be found by using (43) and then D2 / D1 can be calculated.

$$
\begin{equation*}
D 2=W^{k}\left(\alpha_{k}\right) R_{k}-V^{k}\left(\alpha_{k}\right) \tag{43}
\end{equation*}
$$

### 7.3. CALCULATION OF (WK+1(X), VK+1(x)) OR (QTMP(X), NTMP(X))

If $D 1=0$, then equations (44) and (45) are computed.

$$
\begin{align*}
& W^{k+1}(x)=\alpha_{k}\left(W_{8}^{k} x^{8}+W_{7}^{k} x^{7}+\ldots+W_{0}^{k}\right)+  \tag{44}\\
& \left(W_{7}^{k} x^{8}+W_{6}^{k} x^{7}+\ldots+0\right) \\
& V^{k+1}(x)=\alpha_{k}\left(V_{7}^{k} x^{7}+V_{6}^{k} x^{6}+\ldots+V_{0}^{k}\right)+  \tag{45}\\
& \left(V_{6}^{k} x^{7}+V_{5}^{k} x^{6}+\ldots+0\right)
\end{align*}
$$

The numbers of multipliers required to calculate $\left(W^{k+1}(x), V^{k+1}(x)\right)$ polynomials are 9 and 8 ; respectively. Here, the 8 multipliers to calculate $W^{\mathrm{k}}\left(\alpha_{\mathrm{k}}\right)$ in section 6.2 are re-used to implement the $W^{k+1}(x)$ circuitry with one extra multiplier is added. Similarly, the multipliers to calculate $V^{\mathrm{k}}\left(\alpha_{k}\right)$ in section 6.2 are also re-used to implement the $V^{k+1}(x)$ circuitry with one extra multiplier is added. There is no required update on ( $Q^{k}(x), N^{k}(x)$ ) polynomials, hence ( $Q^{k+1}(x), N^{k+1}(x)$ ) polynomials are already available. $J^{k+1}$ value needs to be updated, hence $J^{k+1}=J^{\mathrm{k}}+1$.

On the other hand, when $D 1 \neq 0$, then the following equations will be computed and the hardware used will be the one on the case of $D 1=0$.

$$
\begin{align*}
& Q^{t m p}(x)=\alpha_{k}\left(Q_{8}^{k} x^{8}+Q_{7}^{k} x^{7}+\ldots+Q_{0}^{k}\right)+  \tag{46}\\
& \left(Q_{7}^{k} x^{8}+Q_{6}^{k} x^{7}+\ldots+0\right) \\
& N^{t m p}(x)=\alpha_{k}\left(N_{7}^{k} x^{7}+N_{6}^{k} x^{6}+\ldots+N_{0}^{k}\right)+  \tag{47}\\
& \left(N_{6}^{k} x^{7}+N_{5}^{k} x^{6}+\ldots+0\right)
\end{align*}
$$

## 7.4. (WTMP(X), VTMP(X)) CALCULATION

At this stage, the $W^{\mathrm{tmp}}(x)$ and $V^{\mathrm{tmp}}(x)$ polynomials have to be found. The way to get the $W^{\mathrm{tmp}}(x)$ polynomial is by multiplying $D 2 / D 1$ value with $Q^{\mathrm{k}}(x)$ polynomial, and then adding the $W^{\mathrm{k}}(x)$ polynomial, as shown in equation (48).

$$
\begin{align*}
& W^{t m p}(x)=\frac{D 2}{D 1}\left(Q_{8}^{k} x^{8}+Q_{7}^{k} x^{7}+\ldots+Q_{0}^{k}\right)+  \tag{48}\\
& \left(W_{8}^{k} x^{8}+W_{7}^{k} x^{7}+\ldots+W_{0}^{k}\right)
\end{align*}
$$

The number of multipliers required is 9 and it will re-use the multipliers to implement $W^{\mathrm{k}+1}(x)$ or $Q^{\operatorname{tmp}}(x)$ in section 6.3. Similar fashion is applicable to find $V^{\mathrm{mmp}}(x)$ polynomial using equation (49).

$$
\begin{align*}
& V^{t m p}(x)=\frac{D 2}{D 1}\left(V_{7}^{k} x^{7}+V_{6}^{k} x^{6}+\ldots+V_{0}^{k}\right)+  \tag{49}\\
& \left(N_{7}^{k} x^{7}+N_{6}^{k} x^{6}+\ldots+N_{0}^{k}\right)
\end{align*}
$$

The number of multipliers required is 8 which have already been used to implement $V^{\mathrm{k}+1}(x)$ or $N^{\mathrm{tmp}}(x)$ on section $\mathbf{c}$. By considering the $J^{\mathrm{k}}$ value, the $W^{\mathrm{k}+1}(x)$, $Q^{\mathrm{k}+1}(x), V^{\mathrm{k}+1}(x)$ and $N^{\mathrm{k}+1}(x)$ polynomials are then updated.

If $J^{\mathrm{k}}=0$ then equation (50) applies, otherwise equation (51).

$$
\begin{align*}
& \left(W^{k+1}(x), V^{k+1}(x)\right)=\left(Q^{t m p}(x), N^{t m p}(x)\right)  \tag{50}\\
& \left(Q^{k+1}(x), N^{k+1}(x)\right)=\left(W^{t m p}(x), V^{t m p}(x)\right)
\end{align*}
$$

and

$$
\begin{align*}
& \left(Q^{k+1}(x), N^{k+1}(x)\right)=\left(Q^{t m p}(x), N^{t m p}(x)\right)  \tag{51}\\
& \left(W^{k+1}(x), V^{k+1}(x)\right)=\left(W^{t m p}(x), V^{t m p}(x)\right)
\end{align*}
$$

### 7.5. FINITE FIELD EXPONENTIATION

In section 6.1 and 6.2 , it has been assumed that $\alpha_{k}{ }^{2}, \alpha_{k}{ }^{3}, \ldots, \alpha_{k}{ }^{8}$ are available. In this section, it will be explained how to obtain $\alpha_{k}{ }^{2}, \alpha_{k}{ }^{3}, \ldots, \alpha_{k}{ }^{8}$ by performing multiplication less than 7 times.

Consider $G F\left(2^{8}\right)$ with $p(x)=x^{8}+x^{4}+x^{3}+x^{2}+1$ and take $\alpha$ to be a root of $p(x)$. Let

$$
\left.\begin{array}{l}
x=\left(\begin{array}{c}
x_{0} \\
x_{1} \\
x_{2} \\
x_{3} \\
x_{4} \\
x_{5} \\
x_{6} \\
x_{7}
\end{array}\right), \text { then it can be shown that } x^{2}=\left(\begin{array}{c}
x_{0}+x_{4}+x_{6}+x_{7} \\
x_{7} \\
x_{1}+x_{4}+x_{5}+x_{6} \\
x_{4}+x_{6} \\
x_{2}+x_{4}+x_{5}+x_{7} \\
x_{5} \\
x_{3}+x_{5}+x_{6} \\
x_{6} \\
x_{0}+x_{2}+x_{3}+x_{6} \\
x_{6} \\
x_{2}+x_{3}+x_{4}+x_{5}+x_{6} \\
x_{2}+x_{3}+x_{4}+x_{6}+x_{7} \\
x_{1}+x_{2}+x_{5}+x_{7} \\
x_{5} \\
x_{3}+x_{4} \\
x_{3}+x_{5}+x_{6}
\end{array}\right) \text { and } x^{8}=\left(\begin{array}{c}
x_{0}+x_{1}+x_{3}+x_{4}+x_{7} \\
x_{3}+x_{5}+x_{6} \\
x_{1}+x_{2}+x_{3}+x_{4}+x_{6}+x_{7} \\
x_{1}+x_{2}+x_{3}+x_{4}+x_{5}+x_{7} \\
x_{1}+x_{4}+x_{7} \\
x_{5} \\
x^{4} \\
x_{2}+x_{5}+x_{6}+x_{7} \\
x_{3}+x_{4}
\end{array}\right. \\
\end{array}\right)
$$

The combination of this method and multiplication is carried out to perform $x^{k^{\prime}}$ (where $k^{\prime} \neq 2,4,8$ ).

## 8. VHDL Decoder Using the WB algorithm Pin Out Connection

The HDD pins both input and output connections are as follows.

1) parity_number
: integer input 8.
2) Input clk : clock active on rising edge.
3) Input reset_n : active low asynchronous reset.
4) Input reset_sync_n : active low synchronous reset.
5) Input $d i$ : 8-bits input data to be decoded.
6) Input $d i \_r d y \quad$ active high flag to indicate that $d i$ is valid.
7) Input di_sync_in active high flag to synchronise the codeword.
8) Input do_acpt : active high flag to indicate that $d o$ is already taken.
9) Output $d o \quad$ : the 8 bits decoder output.
10) Output $d o \quad r d y \quad$ active high flag to indicate that $d o$ is valid.
11) Output di_acpt : active high flag to indicate that $d i$ is already taken.
12) Output do_sync_out : active high flag to synchronize the output.
13) Output do_error : active high flag when a correction taken place.
14) Output do_parity_n : active low flag at a parity check location.

## Timing

The decoder timing diagram is shown in Error! Reference source not found.Error! Reference source not found. The first stage of the decoding is reencoding which occupies 1 codeword period. Solving the key equation is carried out at the next stage using the WB algorithm. The allocated time is also 1 codeword period, even though the WB algorithm process only requires $8 t$ clock cycles. There are $2 t$ check pairs need to be solved and every pair requires 4 clock cycles to proceed. After completing the algorithm process, the Chien search is carried out to solve the error locator polynomial and then the error value is computed to recover the corrupted message.


Figure 9. The timing diagram of $R S$ Decoder using the WB algorithm.

## Simulation Results

Consider $\operatorname{RS}(255,239)$. Let $c(x)$ be the transmitted message and $v(x)$ be the received message.
$c(x)=\{0,0,0,0,0,0,0,0,0,0,0,0, \ldots, 0\}$
$v(x)=\{1,2,4,8,16,32,64,128,0,0,0,0, \ldots, 0\}$
The simulation result was shown in Error! Reference source not found. where all zeros became the decoder output. $v(x)$ is represented as din ff, the error value is evalue, the corrected value is corrected, and the decoder output is wb_do.

Another example, consider again $\operatorname{RS}(255,239)$. Let $I(x)$ be the information message before encoding at the value of $\{0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, \ldots, 0 \mathrm{x} 0 \mathrm{~F}\}$. Then the encoded transmitted message will be $c(x)=\{0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}$, $0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{x} 0 \mathrm{~F}, \ldots, 0 \mathrm{x} 0 \mathrm{~F}, 0 \mathrm{xA} 9,0 \mathrm{xCC}, 0 \mathrm{x} 91,0 \mathrm{x} 43,0 \mathrm{x} 2 \mathrm{C}, 0 \mathrm{x} 7 \mathrm{C}, 0 \mathrm{x} 63,0 \mathrm{x} 7 \mathrm{~B}$, $0 \times 22,0 \times 55,0 x 01,0 x 87,0 x F 1,0 x 2 B, 0 x B 1,0 x 6 A\}$.

Let $e(x)$ be the error value and $v(x)$ be the received message, then
$e(x)=\{0 \mathrm{x} 03,0 \mathrm{x} 03,0 \mathrm{x} 03,0 \mathrm{x} 03,0 \mathrm{x} 03,0 \mathrm{x} 03,0 \mathrm{x} 03,0 \mathrm{x} 03,0, \ldots, 0,0,0,0,0,0$, $0,0,0,0,0,0,0,0,0,0,0,0,0\}$.
$v(x)=c(x)+e(x)=\{0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{C}, 0 \mathrm{x} 0 \mathrm{~F}$, $\ldots, 0 x 0 \mathrm{~F}, 0 \mathrm{xA} 9,0 \times \mathrm{CC}, 0 \mathrm{x} 91,0 \mathrm{x} 43,0 \times 2 \mathrm{C}, 0 \times 7 \mathrm{C}, 0 \mathrm{x} 63,0 \times 7 \mathrm{~B}, 0 \times 22,0 \times 55,0 \times 01$, $0 \times 87,0 \times F 1,0 \times 2 \mathrm{~B}, 0 \mathrm{xB} 1,0 \times 6 \mathrm{~A}\}$.

The decoder output $d o$ is shown on Error! Reference source not found. and this value is valid when $d o \quad r d y$ is set to logic ' 1 '. Error! Reference source not found. shows that the decoder output $d o$ is equal to the encoded transmitted message $c(x)$.

Reed Solomon Codes for Reliable Communication in Internet of Things (IOT) 21


Figure 10. The simulation result for $\operatorname{HDD} \operatorname{RS}(255,239)$.


Figure 11. The simulation result for $\operatorname{HDD} \operatorname{RS}(255,239)$.

## Synthesis Results

The VHDL source code was then synthesized using Quartus II software. The Altera Stratix EP1S25-B672C6 was selected to be the target device with a capacity of 25660 logic element (LE). The design utilized 8651 out of 25660 ( $33 \%$ coverage) logic element at maximum clock frequerncy 86.23 MHz . A synthesize result of $\operatorname{HDD} \operatorname{RS}(255,239)$ is shown in Figure 12, where the black solid part is the utilised area.


Figure 12. The synthesize result for $\operatorname{HDD} \operatorname{RS}(255,239)$.

## 9. CONCLUSION

We have presented Reed-Solomon (RS) code, one of many error control coding schemes, to enhance the security of data and information exchanges along the internet connections in Internet of Things. Reed-Solomon code has been discussed in detail. RS decoding scheme using the Welch Berlekamp algorithm has also been highlighted. The VHDL implementation of Reed Solomon decoder is also presented. Without loss of generality, the Hard Decision Decoding for $\operatorname{RS}(255,239)$ over GF(28) is developed using VHDL.

## References

[1]. Meutia, E.D. (2015). Internet of Things - Keamanan dan Privasi. Seminar Nasional dan Expo Teknik Elektro, ISSN: 2088-9984, 85-89. (In Indonesian language)
[2]. C. Qiang, G. Quan, B. Yu, L. Yang. (2013). Research on Security Issues of the Internet of Things. International Journal of Future Generation Communication and Networking, Vol.6, No.6, 1-10.
[3]. Tiwari, A. and Maurya, H. (2017). Challenges and Ongoing Researches for IOT (Internet of Things): A Review. International Journal of Engineering Development and Research, vol 5, issue 2, 57-60.
[4]. Shannon, C.E. (1948). A Mathematical Theory of Communication. Bell system Tech Journal, 27: 379-423.
[5]. Reed, I.S. and Solomon, G. (1960). Polynomial codes over certain finite fields. Journal Society. Industrial Applied Maths, 8: 300-304.
[6]. Chang, H.C. and Shung, C.B. (1998). A (208, 192; 8) Reed Solomon Decoder for DVD Application. IEEE International Conference On Communications Conf. Record, affiliated with Supercomm, 2: 957-960.
[7].Hoeve, H., Timmermans, J. and Vries, L.B. (1982). Error correction and concealment in the compact disc system. Phillips Tech. Rev, 40, 6: 166-172.
[8].Im, Y. and Kwon, O.S. (1997). An Advanced VLSI Architecture of RS Decoders for Advanced TV. IEEE Intternational Conference On. Communications - Towards the Knowledge Millenium ICC'97, 3: 1346-1350.
[9]. Kwon, S. and Shin, H. (1997). An Area Efficient VLSI Architecture of a ReedSolomon Decoder/Encoder for Digital VCRs. IEEE Transactions On Consumer Electronics, 43-4: 1019-1027.
[10]. Shayan, Y.R., Le-Ngoc, T. and Bhargava, V.K. (1990). Design of RS (16, 12) Codec for North American Advanced Train Control System. IEEE Transactions of Vehicular Tech, vol. 39, no 4.
[11]. Blahut, R.E. (1983). Theory and Practice of Error Control Codes. Reading MA, Addison-Wesley.
[12]. Clark, G.C. and Cain, J.B. (1981). Error-Correction Coding for Digital Communications. Applications of Communications Theory, Plenum Press, New York.
[13]. Berlekamp, E.R. (1982). Bit Serial Reed-Solomon Encoders. IEEE Trans. Inform. Theory, 28: 869-874.
[14]. Bossert, M. (1999). Channel Coding for Telecommunications. John Wiley publisher.
[15]. Hsu, I.S., Reed, I.S., Truong, T.K., Wang, K., Yeh, C.S. and Deutsch, L.J. (1984). The VLSI Implementation of a Reed-Solomon Encoder Using Berlekamp's Bit Serial Multiplier algorithm. IEEE Trans. Comp, vol. 33.
[16]. Liu, K.Y. (1984). Architecture for VLSI Design of a Reed-Solomon Decoder. IEEE Trans. Comp, vol. 33.
[17]. Bhargava, W. Reed-Solomon Codes and Their Applications. IEEE press.
[18]. Blahut, R.E. (1979). Transform Technique for Error Control Codes. IBM Journal Res. Develop., vol 23 no 3, 299-315.
[19]. Blahut, R.E. (1984). A Universal Reed-Solomon Decoder. IBM Journal Res. Develop., vol 28 no 2, pp 150-158.
[20]. Shao, H.M., Truong, T.K., Deutsch, L.J., Yuen, J.H. and Reed, I.S. (1985). A VLSI Design of a Pipeline Reed-Solomon Decoder. IEEE Trans on Computers, Vol C34, no. 5, pp. 393-403.
[21]. Brent, R.P. and Kung, H.T. (1984). Systolic VLSI Arrays for Polynomial GCD Computation. IEEE Trans. on Computers, vol 33 no 8, pp 731-736.
[22]. Dabiri, D. and Blake, I.F. (1995). Fast Parallel algorithms for Decoding Reed-Solomon Codes Based on Remainder Polynomials. IEEE Trans. on Inform. Theory, vol. 41 no 4, pp. 873-885.
[23]. Fitzpatrick, P. (1996). On The Scalar Rational Interpolation Problem. Mathematics of Control, Signals and Systems, vol 9 part 4, pp 352-369.
[24]. Blackburn, S.R. and Chambers, W.G. (1996). Some Remarks on an algorithm of Fitzpatrick. IEEE Trans. on Inform. Theory, vol 42 no 4, pp 12691271.
[25]. Massey, J.L. (1969). Shift-Register Synthesis and BCH Decoding. IEEE Trans. Inform. Theory, vol. 15, no. 1, pp. 122-127.
[26]. Welch, L. and Berlekamp, E.R. (1986). Error Correction for Algebraic Block Codes. US Patent 4,633,470.
[27]. Morii, M. and Kasahara, M. (1992). Generalized Key Equation of Remainder Decoding algorithm for Reed Solomon Codes. IEEE Trans. Inform. Theory, vol. IT 38, 1801-1807.
[28]. Chambers, W.G. (1993). Solution of Welch-Berlekamp Key Equation by Euclidean algorithm. Electronic Letters, vol 29 no 11, pp 1031.
[29]. Chambers, W.G., Peille, R.E., Tsie, K.Y. and Zein, N. (1993). Algorithm for Solving the Welch-Berlekamp Key-Equation, with a Simplified Proof. Electronic Letters, vol 29 no 18, pp 1620-1621.
[30]. Peille, R.E. (1994). On the Performance and Complexity of a Generalized Minimum Distance Reed-Solomon Decoding algorithm. International Journal of Satellite Communications, vol 12, pp. 333-359.
[31]. Jennings, S.M. (1995). Grobner Basis View of Welch-Berlekamp algorithm for Reed-Solomon Codes. IEE Proc. Commun., vol 142 no 6, pp 349351.
[32]. Sorger, U.K. (1993). A New Reed-Solomon Code Decoding algorithm Based on Newton's Interpolation. IEEE Trans. Inform. Theory, vol. 39, no 2, pp. 358-365.
[33]. Chien, R.T. (1964), Cyclic Decoding Procedures for BCH Codes. IEEE Trans. on Inform. Theory, vol. 10, pp. 357-363.
[34]. Mahmudi, A., Achmadi, A. And Michael (2018), Modified Welch Berlekamp Algorithm to Decode Reed Solomon Codes, MATEC Web of Conferences Vol 164 (2018), The 3rd International Conference on Electrical Systems, Technology and Information (ICESTI 2017)

## VIJEY THAYANANTHAN，PH．D．

## EDITOR



ADVANCED SECURITY ISSUES OF IOT BASED 5G PLUS WIRELESS COMMUNICATION FOR INDUSTRY 4.0 CロMPUTER SCIENCE，TECHNロLロGY AND APPLICATIロNS

# Advanced Security Issues of IoT Based 5G Plus Wireless Communication FOR INDUSTRY 4.0 

ViJEY THAYANANTHAN<br>Editor

nova
science publishers

Complimentary Contributor Copy

Copyright © 2019 by Nova Science Publishers, Inc.

All rights reserved. No part of this book may be reproduced, stored in a retrieval system or transmitted in any form or by any means: electronic, electrostatic, magnetic, tape, mechanical photocopying, recording or otherwise without the written permission of the Publisher.

We have partnered with Copyright Clearance Center to make it easy for you to obtain permissions to reuse content from this publication. Simply navigate to this publication's page on Nova's website and locate the "Get Permission" button below the title description. This button is linked directly to the title's permission page on copyright.com. Alternatively, you can visit copyright.com and search by title, ISBN, or ISSN.

For further questions about using the service on copyright.com, please contact:
Copyright Clearance Center
Phone: +1-(978) 750-8400
Fax: +1-(978) 750-4470
E-mail: info@copyright.com.

## NOTICE TO THE READER

The Publisher has taken reasonable care in the preparation of this book, but makes no expressed or implied warranty of any kind and assumes no responsibility for any errors or omissions. No liability is assumed for incidental or consequential damages in connection with or arising out of information contained in this book. The Publisher shall not be liable for any special, consequential, or exemplary damages resulting, in whole or in part, from the readers' use of, or reliance upon, this material. Any parts of this book based on government reports are so indicated and copyright is claimed for those parts to the extent applicable to compilations of such works.

Independent verification should be sought for any data, advice or recommendations contained in this book. In addition, no responsibility is assumed by the Publisher for any injury and/or damage to persons or property arising from any methods, products, instructions, ideas or otherwise contained in this publication.

This publication is designed to provide accurate and authoritative information with regard to the subject matter covered herein. It is sold with the clear understanding that the Publisher is not engaged in rendering legal or any other professional services. If legal or any other expert assistance is required, the services of a competent person should be sought. FROM A DECLARATION OF PARTICIPANTS JOINTLY ADOPTED BY A COMMITTEE OF THE AMERICAN BAR ASSOCIATION AND A COMMITTEE OF PUBLISHERS.

Additional color graphics may be available in the e-book version of this book.

## Library of Congress Cataloging-in-Publication Data

ISBN: 978-1-53615-539-6 (ebook)
Published by Nova Science Publishers, Inc. † New York

## CONTENTS

Preface ..... vii
Acronyms ..... ix
Chapter 1 An Overview of 5G and Beyond ..... 1
Vijey Thayananthan and Surekha Lanka
Chapter 2 Reed Solomon Codes for Reliable Communication in Internet of Things ..... 23
Ali Mahmudi
Chapter 3 Efficient Data Traffic Techniques for IoT Based 5G Networks ..... 53
Ahmed Alshaflut and Mohammed Yahya Alzahrani
Chapter 4 Analysis of Cybersecurity for 5G - Based Vehicular Communication Network ..... 71
Javad Yazdani and Vijey Thayananthan
Chapter 5 Cybersecurity Issues in Industry 4.0 ..... 89
Omar Abdulkader, Kamal Jambi and Alwi M. Bamhdi
Complimentary Contributor Copy
Chapter 6 Effective Bandwidth Management for Mitigating DoS Attack in SDN ..... 107
Muhammad Aminu Lawal
Chapter 7 Industry 4.0 and E_Learning Based on 5G System ..... 127
Vijey Thayananthan and Esther Priyadharshini
Chapter 8 Traffic Load Balancing Based on Routing Algorithms for Content-Centric Networking ..... 145
Muhammad Shuaib Qureshi, Muhammad Bilal Qureshi and Hameed Hussain
Chapter 9 Security and Privacy in Location-Based Services for 5G Mobile Communication ..... 165
Abdullah Albelaihy and Jonathan Cazalas
Chapter 10 Learning Style Transformation Using Intelligent IoT, 5G and Beyond ..... 181
Vijey Thayananthan and Benachour Phillip
About the Editor ..... 195
Index ..... 197
Related Nova Publications ..... 209
Complimentary Contributor Copy


[^0]:    * National Institute of Technology (ITN), Jalan Sigura-gura 2, Malang, Indonesia Email: alimahmudi@gmail.com; amahmudi@lecturer.itn.ac.id

