Reliable Wireless Sensor Networks by Using Redundant Residue Number System

Ali Barati¹, Ali Movaghar², Masoud Sabaei³, Samira Modiri⁴

¹Ph.D Student, Department of Computer Engineering and Information Technology, Qazvin Branch, Islamic Azad University, Qazvin, Iran
²Department of Computer Engineering, Sharif University of Technology, Tehran, Iran
³Computer and IT Department, Amir-Kabir University of Technology, Tehran, Iran
⁴Department of Computer Engineering, Dezful Branch, Islamic Azad University, Dezful, Iran
abarati@iaud.ac.ir

Abstract - In this paper, a new scheme using redundant residue number system is proposed for decreasing the total consumption power and thus, increasing the lifetime, and also to reach error controllability to improve reliability of received data and therewith to obtain improvement in end-to-end delay in wireless sensor networks. The proposed scheme employs the new moduli set \(\{2^{2n+1} + 2^{2n-1} - 1, 2^n - 1\}\). Moreover, to complete the new scheme, an efficient reverse converter in both terms of conversion delay and hardware saving is designed and implemented based on mixed radix conversion algorithm.

Index Terms - Redundant Residue Number System, Reverse Converter, Mixed-Radix-Conversion, Wireless Sensor Networks

I. Introduction

Wireless sensor networks technologies with a large number of multifunctional low-power sensor nodes have received tremendous attention because of wide applications in today's world¹. In such as networks, two critical issues are energy conservation and reliability in data delivery². In this paper, using redundant residue number system in wireless sensor network applications is proposed for solving the said problems.

Redundant residue number systems (RRNSs) are appropriate for use in wireless sensor network, because of 3 factors: 1) strong error controllability, 2) low energy consumption, 3) run-time operations.

In RRNS, by considering some modulus, instead of sending number \(X\), the remainders of \(X\) are transmitted, so fewer packets are sending and power consumption is reduced. Receiver using a reverse converter decodes the received packets and recovers the original message and then, detects and corrects error, if occurred.

The most important part of any RNS design is moduli set selection, because it has direct effect on system's speed, its dynamic range and area utilization of reverse converter. The reverse converter is responsible to convert back the received data from RNS to conventional representation and is the most complex of any residue to number system design.

In this paper, the new residue number system moduli set \(\{2^{2n+1} + 2^{2n-1} - 1, 2^n - 1\}\) is proposed and an efficient reverse converter is designed and implement base on the new moduli set that is suitable for wireless sensor networks with low power resources.

II. Advantages Of The Proposed Scheme

Because the absence of carry propagation between the arithmetic blocks results in high speed processing, RNS is high speed. This feature is beneficial for wireless sensor networks that need to run-time applications. RNS needs to reduce power. Because of smaller words are transmitted in RNS representation. Thus smaller arithmetic units are realized in the RNS processors that reduce the switching activities in each channel. This results in reduction in the dynamic power, since the dynamic power is directly proportional to switching activities. Therewith, RNS has parallel operations that reduce power consumption and delay simultaneously.

Moreover, noted that WSNs have wide applications and maybe deployed in a hostile environment, such as battlefield. In these conditions, error control and secure data aggregation is critical for WSNs. However data aggregation operation in WSNs improves the bandwidth and energy utilization, but on the other performance metrics such as delay, accuracy, fault-tolerance and security, it may have negative affect ³.

There is a strong conflict between security and data aggregation protocols². An efficient aggregation scheme must implement data aggregation at every intermediate node and decrypt received data packets and encrypt them again after processing at every node, thus it sacrifice data confidentiality, energy and time of overall network.

Redundant RNS is a suitable solution to solve the mentioned problems, because no need to decrypt and encrypt data in every nodes, thus therewith RRNS is secure, it is an energy saving and real-time scheme too. Moreover, the data confidentiality is hold, because in this approach, moduli set acts as secret key, therefore we have secure channels among sensor nodes. Therewith, the most important benefit of using RRNS that it is an error control scheme. The RNS is a non-positional system with no dependence between its channels. Thus, an error in one channel does not propagate to other channels. Therefore, isolation of the faulty residues allows fault tolerance and facilitates error detection and correction.

III. Design Of The Reverse Converter for Proposed Moduli Set

A residue number system is defined in terms of relatively
prime moduli set \( \{P_1, P_2 \ldots P_n\} \) that is \( \gcd(P_i, P_j) = 1 \) for \( i \neq j \). A weighted number \( X \) can be represented as \( X = (x_1, x_2 \ldots x_n) \), where:
\[
x_i = X \mod P_i = |X|_{P_i}, 0 \leq x_i < P_i
\]  
(1)

Such a representation is unique for any integer \( X \) in the range \([0, M]\), where \( M = (P_1 \times P_2 \times \ldots \times P_n) \) is the dynamic range of the moduli set \( \{P_1, P_2, \ldots, P_n\}\). The residue to binary conversion can be performed using the MRC as follows:
\[
X = V_n P_n \ldots P_1 + V_3 P_3 P_2 + V_2 P_2 + V_1
\]  
(2)

The coefficients \( V_i P_i \) can be obtained from residues by:
\[
V_i = x_i
\]  
(3)
\[
V_2 = |(x_2 - x_1)| P_2^{-1} |P_2|_{P_2}
\]  
(4)
\[
X = V_n P_n \ldots P_1 + V_3 P_3 P_2 + V_2 P_2 + V_1
\]  
(5)

In the general case, we have:
\[
V_n = (((x_n - V_2) |P_n^{-1}|_{P_n} - V_2 |P_n^{-1}|_{P_n} - \ldots - V_{n-1} |P_{n-1}^{-1}|_{P_{n-1}})
\]  
(6)

Where \( |P_i^{-1}|_{P_i} \) denotes the multiplicative inverse of \( P_i \) modulo \( P_i \).

Consider the three new modulus in the moduli set \( \{2^{2n+2}, 2^{2n-1}-1, 2^n-1\} \) with three corresponding residues \( (x_1, x_2, x_3) \). For design a residue to binary converter, firstly need to prove the modulus of proposed moduli set \( \{2^{2n+2}, 2^{2n-1}-1, 2^n-1\} \) are in fact pair wise relatively prime for the validity of the RNS. Next, we should to find the multiplicative inverses, and then the values of the multiplicative inverses and modulus must substitute in conversion algorithm formulas. Then, the resulted equations should be simplified by using arithmetic properties. Finally, simplified equations would realize using hardware components such as full adders and logic gates.

Based on Euclid’s Theorem:
\[
gcd(a, b) = \gcd(b, a \mod b), \quad a > b
\]  
(7)

Hence:
\[
gcd(2^{2n+2}, 2^{2n-1}-1) = \gcd(2^{2n-1}-1, 8) = 1
\]  
(8)
\[
gcd(2^{2n+2}, 2^n-1) = \gcd(2^n-1, 4) = 1
\]  
(9)
\[
gcd(2^{2n-1}-1, 2^n-1) = \gcd(2^n-1, 2^{n-1}-1) = \gcd(2^{n-1}-1, 1) = 1
\]  
(10)

Since the greatest common divisors are one, thus the numbers \( 2^{2n+2}, 2^{2n-1}-1, 2^n-1 \) are relatively prime together. In what follows, by use of three propositions, the closed form expressions for the multiplicative inverses under the MRC are derived that form the basis of our algorithm for the reverse converter.

**Proposition 1**: The multiplicative inverse of \( (2^{2n+2}) \) modulo \( (2^{2n-1}-1) \) is \( k_1 = 2^n - 4 \).

\[
|2^{2n-4} \times 2^{2n+2}|_{2^n-1} = 1
\]  
(11)

Proof:
\[
|2^{2n-4} \times 2^{2n+2}|_{2^n-1} = 1
\]  
(12)

**Proposition 2**: The multiplicative inverse of \( (2^{2n+2}) \) modulo \( (2^n-1) \) is \( k_2 = 2^n - 2 \).

\[
|2^{2n-2} \times 2^{2n+2}|_{2^n-1} = 1
\]  
(12)

Proof:
\[
| -2 \times 2^{2n-1} - 1|_{2^n-1} = 1
\]  
(13)

Therefore, let the values \( k_j = 2^{(2n-d)}, k_2 = 2^{(n-2)}, k_1 = -2, P_1 = 2^{2n+2}, P_2 = 2^{2n-1}, P_3 = 2^n \).

In (2-5) and we have:
\[
X = x_1 + P_3 (V_2 + V_2 P_3)
\]  
(14)
\[
V_1 = x_1
\]  
(15)
\[
V_2 = |(x_2 - x_1)| P_2^{-1} |P_2|_{P_2}
\]  
(16)
\[
V_3 = |(x_3 - x_2)| P_3^{-1} |P_3|_{P_3}
\]  
(17)

According to the following two properties, (14-17) can be simplified to decrease the hardware complexity.

**Property 1**: The residue of a negative residue number \(-v\) in modulo \((2^n-1)\) is the one’s complement of \(v\), where \(0 \leq v < (2^n-1)\).

**Property 2**: The multiplication of a residue number \(v\) in modulo \((2^n-1)\) is carried out by \(P\) bit circular left shift, where \(P\) is a natural number.

For designing an efficient reverse converter, simplify (14,16,17) as follow:
\[
V_2 = [(x_2 - x_1)|P_2^{-1}|_{P_2}
\]
\[
= |2^{2n-4} \times (x_2 - x_1)|_{2^n-1}
\]  
(18)
\[
V_3 = |2^{n-2} \times x_3|_{2^n-1} + 2 |V_2|_{2^n-1}
\]  
(17)

Where,
\[ V_{21} = (2^{2n-4} \times x_2)_{2^{2n-1}-1} = \frac{x_{2,2n-3,2,0} x_{2,n-2} \ldots x_{2,3}}{3 \text{ bits}} \] (21)

\[ V_{22} = | -2^{2n-4} \times x_1 |_{2^{2n-1}-1} = \left\{ \begin{array}{c}
\frac{2 \text{ bits}}{(2n-4) \text{ bits}}
\frac{x_{3,1,3,0,1,2n-3,1,2n-1,1,3}}{9 \text{ bits}} + \frac{x_{3,1,3,0,1,2n-3,1,2n-1,1,3}}{9 \text{ bits}}
\end{array} \right. \] (22)

For realize \( V_3 \) based on (17), we have:

\[ V_3 = |(x_3 - x_1)|_{2^{n-1}} (V_2) = \frac{|x_{2}^{2n-2} \times x_2|_{2^{n-1}}}{2 \text{ bits}} \] (23)

Where,

\[ V_{31} = |2^{n-2} \times x_3|_{2^{n-1}} = \frac{x_{3,1,3,0,1,2n-3,1,2n-1,1,3}}{9 \text{ bits}} \] (24)

Finally, for finding \( X \) based on (14), we have:

\[ X = x_1 + V_3 = (2^{2n-1} - 1)V_3 \] (25)

\[ C = \frac{V_{2,2n-2} \ldots V_{2,0}}{(n-1) \text{ bits}} + \frac{1}{1} \] (26)

\[ X = x_1 + \left(2^{2n+2}\right) C = \text{Concatenation of} \ (x_1, C) \] (27)

IV. Hardware Implementation of The Proposed Reverse Converter

Hardware architecture of the proposed reverse converter for the 3-moduli set \( \{2^{2n+3}, 2^{2n-1} - 1, 2^n - 1\} \) is shown in figure 1. Implementation is based on (18,21,26,28).

Fig.1. Hardware Implementation of Residue to Binary Converter for the Moduli Set \( \{2^{2n+3}, 2^{2n-1} - 1, 2^n - 1\} \)

Firstly, the operand preparation unit (1) (OPU (1)) prepares the required operands (19,20,22,23) and these preparation rely on simply manipulating the routing of the bits of the residues. Realization of (19,20) rely on a \((2n-1)\) -bits carry save adder with end around carry (CSA (1) with EAC) and a \((2n-1)\) -bits carry propagate adder (CPA (1)). \((n-\text{bits})\) - CSA (2) and CSA (3) with EAC are used to implementation of equations (22,23). In these equations, a FA with a constant input “1” can be reduced to a pair of two-input XNOR and OR gates and a FA with a constant input “0” can be reduced to a pair of two-input XOR and AND gates. Moreover, OPU (2) prepare the required operands for equation (26). Realization of(24) relies on 3-operand \(n-\text{bits}\) - CSA (4, 5) with EAC and a modulo \((2n-1)\) adder for implementation of \( V_3 \). Finally, implementation of (27) requires a \(3n-1\) - bits regular CPA. It should be noted realization of (28) rely on simple concatenation without the use of any computational hardware. Area and delay specifications of each part of the proposed converter are shown in table 1. Then, performance of the proposed reverse converter for new 3-moduli set \( \{2^{2n+2}, 2^{2n-1} - 1, 2^n - 1\} \) is compared with the reverse converters that designed for the other moduli sets with the same dynamic range or less in table 2, in terms of area.
utilization and delay of operations. Dynamic range is defined as products of modulus in the moduli set and shows the number of integers than we can show uniquely based on this moduli set.

Table 1. Characterization of Each Part of the Proposed Converter.

<table>
<thead>
<tr>
<th>Parts</th>
<th>FA</th>
<th>NOT</th>
<th>And/Xor</th>
<th>Or/XNOR</th>
<th>Delay</th>
</tr>
</thead>
<tbody>
<tr>
<td>OPU(1)</td>
<td>-</td>
<td>(2n+2)</td>
<td>-</td>
<td>-</td>
<td>t_{NOT}</td>
</tr>
<tr>
<td>CSA(1)</td>
<td>2n</td>
<td>-</td>
<td>(2n-4)</td>
<td>-</td>
<td>t_{PA}</td>
</tr>
<tr>
<td>CPA(1)</td>
<td>(2n-1)</td>
<td>-</td>
<td>-</td>
<td>(4n-2)t_{PA}</td>
<td></td>
</tr>
<tr>
<td>CSA(2)</td>
<td>m</td>
<td>-</td>
<td>-</td>
<td>t_{PA}</td>
<td></td>
</tr>
<tr>
<td>CSA(3)</td>
<td>2m</td>
<td>-</td>
<td>-</td>
<td>t_{PA}</td>
<td></td>
</tr>
<tr>
<td>CSA(4)</td>
<td>m</td>
<td>-</td>
<td>-</td>
<td>t_{PA}</td>
<td></td>
</tr>
<tr>
<td>CPA(2)</td>
<td>m</td>
<td>-</td>
<td>-</td>
<td>(2n)t_{PA}</td>
<td></td>
</tr>
<tr>
<td>OPU(2)</td>
<td>-</td>
<td>n</td>
<td>-</td>
<td>t_{NOT}</td>
<td></td>
</tr>
<tr>
<td>CPA(1)</td>
<td>m</td>
<td>-</td>
<td>-</td>
<td>(2n-1)t_{PA}</td>
<td></td>
</tr>
</tbody>
</table>

\[
(7n + 3)A_{FA} + (3n + 2)A_{NOT} + (2n - 3)A_{AND} + (2n - 3)A_{XOR} + (3n - 3)A_{OR} + (3n - 3)A_{XNOR} + (2n+2)t_{FA} + 2t_{NOT}
\]

V . Conclusions

This paper proposes a new scheme for wireless sensor networks applications. The presented scheme is based on redundant residue number system and employs a new 3-moduli set and a reverse converter. An efficient reverse converter based on mixed radix conversion algorithm designs and implements completely. Comparison with the other reverse converters for the moduli sets with the same and even less dynamic range demonstrates the proposed reverse converter has preference in terms of area utilization and speed of operations. Thus the proposed scheme based on the new moduli set and the presented reverse converter is suitable for wireless sensor networks applications that need to reliability, and low-power consumer and fast operations parts.

Table 2. Area and Delay comparison between the proposed reverse converter and related works.

<table>
<thead>
<tr>
<th>Converter</th>
<th>Area ((A_{FA}))</th>
<th>Delay ((t_{FA}))</th>
</tr>
</thead>
<tbody>
<tr>
<td>[8]</td>
<td>(8n + 2)</td>
<td>(12n + 5)</td>
</tr>
<tr>
<td>[9]</td>
<td>((5n^2 + 43n)/6 + 16n - 1)</td>
<td>(18n + 7)</td>
</tr>
<tr>
<td>[10]</td>
<td>(10n + 5)</td>
<td>(13n + 1)</td>
</tr>
<tr>
<td>[11]</td>
<td>(12.5n + 6)</td>
<td>(12n + 6)</td>
</tr>
<tr>
<td>[12]</td>
<td>(10n + 5)</td>
<td>(12n + 1)</td>
</tr>
<tr>
<td>[13]-1</td>
<td>(9n + 5)</td>
<td>(11.5n + 6)</td>
</tr>
<tr>
<td>[13]-2</td>
<td>(8n + 4)</td>
<td>(9n + 6)</td>
</tr>
<tr>
<td>[13]-3</td>
<td>(n^2 + 12n + 12)</td>
<td>(16n + 22)</td>
</tr>
<tr>
<td>[13]-4</td>
<td>(9n + 10)</td>
<td>(11n + 14)</td>
</tr>
<tr>
<td>[14]-1</td>
<td>(n^2/2 + 11n + 4)</td>
<td>(11n + 8)</td>
</tr>
<tr>
<td>[14]-2</td>
<td>(n^2 + 10n + 3)</td>
<td>(9n + 6)</td>
</tr>
<tr>
<td>[15]-CICE</td>
<td>2.5n^2 + 25.5n + 12</td>
<td>18n + 23</td>
</tr>
<tr>
<td>[15]-CIHS</td>
<td>2.5n^2 + 37.5n + 28</td>
<td>12n + 15</td>
</tr>
<tr>
<td>[15]-C2CE</td>
<td>20n + 17</td>
<td>13n + 22</td>
</tr>
<tr>
<td>[15]-C3CE</td>
<td>23n + 11</td>
<td>16n + 14</td>
</tr>
<tr>
<td>Proposed</td>
<td>7n + 3</td>
<td>9n + 2</td>
</tr>
</tbody>
</table>

References