## RESEARCH ARTICLE

OPEN ACCESS

# FPGA Based Decimal Matrix Code for Passive RFID Tag

Neelappa<sup>1</sup>, N.G.Kurahatti<sup>2</sup>

<sup>1</sup>Asst. Professor, Department of E and C, Govt. Engineering College Kushalanagar, Karnataka-571234. <sup>2</sup>Professor, Department of E and C, East point college of Engineering and Technology, Bangalore, Karnataka

# ABSTRACT

In this paper, Decimal Matrix Code is developed for RFID passive tag. The proposed DMC uses the decimal algorithm to obtain the maximum error detection and correction capability. The Encoder-Reuse Technique is used to minimize the area overhead of extra circuits without disturbing the complete encoding and decoding processes. ERT uses DMC encoder itself to be part of the decoder. The Simulation results reveals that the Decimal Matrix Code is effective than existing Matrix and Hamming odes in terms of Error Correction Capability. Xilinx ISE 14.7 Software is used for the simulation outputs. The complete design is verified and tested on Spartan-6 FPGA board. The performance of system is measured in terms of power, area and delay. The Synthesis result shows that, the power required for complete design of Decimal Matrix Code is 0.1mW with a delay of 3.109ns.

Keywords: RFID, base band processor, HDL, FPGA, DMC

# I. INTRODUCTION

Radio Frequency Identification (RFID) is "An automatic identification technology that uses radio frequency signals to transmit the identity of objects in the form of a unique serial number". This technology does not use line of sight for communication between reader and tag. It is the best choice for automatic identification due to flexibility, easy to use, contactless, multiple tag identification, high data rate, long read range and the lowest cost. RFID application is growing in many fields such as smart table, access control, animal tracking, logistics, supermarkets, airport baggage handling, antifraud systems and medical treatment [1-5]. RFID system consists of reader, tag and antenna. The reader has antenna that send/receive radio frequency signals to/from tags. Tag shares the data with the reader through radio frequency signals. The main component of the tag is digital base band processor which controls the all the functions of the tag. Several Decimal Matrix Code have been presented before namely, Jing Guo,[8] presented a paper on a "Enhanced Memory Reliability Against Multiple Cell Upsets Using Decimal Matrix Code" with reduced power consumption and chip area with a power consumption of about 10.8mW and area 41572.6μm<sup>2</sup>. The challenge in designing UHF passive RFID tag is to reduce power consumption because the energy of a passive tag comes from the signal sent by a reader and also it is a power limited device. The operation range of a RFID system depending on the maximum of the dynamic power of the tag. There are static power dissipation and dynamic power dissipation in the VLSI circuit. Dynamic power dissipation includes switching power due to charge and discharge of load

capacitance of input signals. Static power dissipation result from the leakage current when the logic gate is static [6]. To reduce power consumption and area in RFID tag, a DMC coding technique is included and there by power dissipation, area and delay of the RFID tag are reduced. In this proposed paper, we have developed a DMC coding technique for UHF RFID tag which includes, encoding and decoding architecture compatible with ISO/IEC 1800-6 tag on Spartan 6 FPGA to observe its functionality. The DMC coding technique is developed by ModelSim is implemented and verified on Spartan-6 FPGA. This paper is organized as follows: Section 2 defines DMC encoder. Section 3 describes DMC encoder. Section 4 simulation results. Finally

## **II. DMC ENCODER**

section 5 presents the Conclusion.

DMC Encoder, which uses decimal algorithm to increase the error detection and correction capability. In this algorithm power consumed will be less compared to other detection methods. This algorithm involves decimal integer subtraction and integer addition. In the decimal algorithm, the divide-symbol and arrange-matrix are performed. Here the N-bit word is divided into n symbols of m bits  $(N = n \times m)$ , and these symbols are arranged in a n=  $n1 \times n2$  2-D matrix (n<sub>1</sub>=number of columns and  $n_2$  =number of rows). The horizontal redundant bits H are obtained by performing decimal integer addition on symbols per row. Finally, then vertical redundant bits V are obtained by binary operation on the bits per column. It is noted that both divide-symbol and arrange-matrix are presented in logical instead of in physical.



Figure.2.1.1 32-bits DMC logical Organization [8]

To explain the DMC scheme, take a 32-bit word is input, which is shown in Fig.2.1.1. The cells from  $D_0$  to  $D_{31}$  are information bits. This 32-bit word has been divided into eight symbols of 4-bits.  $n_1=2$  and  $n_2=4$  have been chosen simultaneously.  $H_0 - H_{19}$ are horizontal check bits;  $V_0$  through  $V_{15}$  are vertical check bits.

The horizontal redundant bits H can be obtained by decimal integer addition as follows:

| $H_4 H_3 H_2 H_1 H_0 = D_3 D_2 D_1 D_0 + D_{11} D_{10} D_9 D_8$ | 1 |
|-----------------------------------------------------------------|---|
| $H_7 H_6 H_5 = D_7 D_6 D_5 D_4 + D_{15} D_{14} D_{13} D_{12}$   | 2 |

Similarly other remaining horizontal redundant bits are obtained where "+"represents decimal integer addition.

For the vertical redundant bits V, we have

| $V_0 = D_0 \bigoplus D_{16}$ | 3 |
|------------------------------|---|
| $V_1 = D_1 \bigoplus D_{17}$ | 4 |

In a similar manner remaining vertical redundant bits are obtained. The encoding can be done by decimal and binary addition operations from (1) to (4). The encoder that computes the redundant bits using multi-bit adders and XOR gates is shown in Fig.2.1.2 In this figure, H19–H0 are horizontal redundant bits,  $V_{15}-V_0$  are vertical redundant bits, and the remaining bits  $U_{31}-U_0$  are the information bits which are directly copied from  $D_{31}$  to  $D_0$ .



Fig. 2.1.2 32 bit DMC encoder structure using multi bit adders and XOR gate [8]

#### **III. DMC Decoder**

For the correction of word obtained, the decoding process is required. At the beginning, the received redundant  $H_4H_3H_2H_1H_0'$  and  $V_0' - V_3'$  are generated by the received information bits D'. Secondly, the horizontal syndrome bits

 $H_4H_3H_2H_1H_0$  and the vertical syndrome bits S3 –S0 can be calculated as follows:

|                              | 5 |
|------------------------------|---|
| $S3 - S_0 = V_0' \oplus V_0$ | 6 |

Similarly for the remaining vertical syndrome bits. Where "-" represents decimal integer subtraction. When  $\triangle H_4H_3H_2H_1H_0$  and  $S_3 - S_0$  are equal to zero, the stored codeword has original information bits in symbol 0 are nonzero, then there is an error. Induced errors are detected and located in symbol 0 and these errors can be corrected by





Figure.2.2.1 32-bit DMC decoder [8]

The DMC decoder is used in our design is shown in Fig.2.2.1, which consists of Syndrome calculator, Error locator, and Error corrector. Here, each module performs a particular function in the decoding process. It is noted from Fig. 2.2.1, that the redundant bits re obtained from the received information bits 'D' and compared with the original set of redundant bits in order to obtain the syndrome bits  $\triangle H$  and S. Then, error locator uses  $\triangle H$  and S to detect and locate error bits. Finally, the error corrector corrects the error bits by inverting the values of error bits. The 'En' signal is used to decide whether encoder is a part of the decoder.

#### **IV. SIMULATION RESULTS**

The proposed design has been done in Verilog HDL. Simulated using model Sim Simulator. For synthesis, we have used the EDA tool Xilinx and all sub module simulation results and top module results are shown in the following sections. Figure.4.1 shows the simulation result and of encoder module. Input is a 32-bit tag ID number and generates 20-bit horizontal and 16-bit vertical redundant numbers as output.



Figure.4.1.Simulation result of encoder

Figure.4.2 shows the simulation result of transmitter module. The 32-bit Tag ID number is input to this module. It generates a output frame of 68-bit length. The frame contains 16-bit vertical redundant number, 20-bit horizontal redundant number and 32-bit input.

|                                                             |              |           |                   |        |       | 79.000000 | us    |
|-------------------------------------------------------------|--------------|-----------|-------------------|--------|-------|-----------|-------|
|                                                             |              |           |                   |        |       |           |       |
| Name                                                        | Value        | <br>72 us | 74us              | 176 us | 78 us |           | 80 us |
| l <mark>a</mark> dk                                         | 1            |           |                   |        |       |           |       |
| ll <mark>a</mark> rst                                       | 0            |           |                   |        |       |           |       |
| ▶ <table-of-contents> rfid_tag_no[31:0]</table-of-contents> | 12345678     |           | 12345678          |        |       |           |       |
| encoder_out[67:0]                                           | 444c2198e123 |           | 444c2198e12345678 |        |       |           |       |
| ▶ 🍇 msg_data[31:0]                                          | 12345678     |           | 12345678          |        |       |           |       |
| ▶ 🔣 encoder_v(15:0)                                         | 444c         |           | 444c              |        |       |           |       |
| ▶ 🔣 encoder_h[19:0]                                         | 2198e        |           | 2198e             |        |       |           |       |
|                                                             |              |           |                   |        |       |           |       |
|                                                             |              |           |                   |        |       |           |       |

Figure.4.2 Simulation result of transmitter

The Figure.4.3 shows simulation result of encoder in receiver. The received data may be corrupted due to the transmission error. So, the error data is given to this module as an input, then it generates 20-bit horizontal redundant bits and 16-bit vertical redundant bits derived from error data as an output.

| Name        | Value    | 12,999,995 ps | 12,999,996 ps | 12,999,997 ps | 12,999,998 ps | 12,999,999 ps |
|-------------|----------|---------------|---------------|---------------|---------------|---------------|
| 🕨 📑 d[31:0] | 12345687 |               |               | 12345687      |               |               |
| ▶ 👫 h[19:0] | 219ad    |               |               | 219ad         |               |               |
| 🕨 🕌 v[15:0] | 44b3     |               |               | 44b3          |               |               |
|             |          |               |               |               |               |               |
|             |          |               |               |               |               |               |
|             |          |               |               |               |               |               |
|             |          |               |               |               |               |               |
|             |          |               |               |               |               |               |
|             |          |               |               |               |               |               |



Figure. 4.4 shows the simulation result of CRC module, to check whether the received data bits are correct or not. It calculates the vertical syndrome bits by XORing the original vertical V [15-0] bits with the vertical bits being derived from received data  $V_d$  [15-0].



Figure.4.4 Simulation result of CRC for vertical syndrome bits

Figure.4.5 shows the simulation result of CRC module, to calculate horizontal syndrome and whether the received data bits are corrupted or not. It calculates the horizontal syndrome bits by subtracting the original horizontal H [19-0] bits with the horizontal bits which are derived from received data  $H_d$  [19-0]. If it is non-zero value the data is corrupted otherwise it is not corrupted.



syndrome bits

The Figure 4.6 shows simulation result of corrector, the 32-bit error data, computed 20-bit horizontal syndrome bits and 16-bit vertical syndrome bits given as an input to the model. It generates a output of corrected 32-bit data.

| Name                                               | Value    | 9 us | 10 us | 11 us    | 12 us | 13 us |
|----------------------------------------------------|----------|------|-------|----------|-------|-------|
| l <mark>a</mark> cik                               | 1        |      |       |          |       |       |
| 埍 rst                                              | 0        |      |       |          |       |       |
| 🕨 <table-of-contents> d1[31:0]</table-of-contents> | 12345687 |      |       | 12345687 |       |       |
| 🕨 📑 s[15:0]                                        | 00ff     |      |       | 00ff     |       |       |
| 🕨 📑 h0h4[4:0]                                      | 1f       |      |       | 1f       |       |       |
| 🕨 📑 h5h9[4:0]                                      | 01       |      |       | 01       |       |       |
| 🕨 📑 h10h14[4:0]                                    | 00       |      |       | 00       |       |       |
| 🕨 📑 h15h19[4:0]                                    | 00       |      |       | 00       |       |       |
| 🕨 📲 d[31:0]                                        | 12345678 |      |       | 12345678 |       |       |
|                                                    |          |      |       |          |       |       |

Figure 4.6 Simulation waveform of corrector

Figure.4.7 shows the simulation result of receiver module, the 68-bit frame is input and generates 32-bit decoded data as an output. It performs the data correction if it is required. This module is comprised of CRC and error corrector modules.

| Name                                                     | Value           | <br>3,000 ns | 3,500 ns | 4,000 ns         | 4,500 ns | 5,000 ms | 5,500 ns |
|----------------------------------------------------------|-----------------|--------------|----------|------------------|----------|----------|----------|
| l <mark>in</mark> cik                                    | 1               |              |          |                  |          |          | i        |
| 🖫 rst                                                    | 0               |              |          |                  |          |          |          |
| ▶ <table-of-contents> rx_frame[67:0]</table-of-contents> | 444c2198e123456 |              |          | 444c2198e1234567 |          |          |          |
| ▶ 👹 decoder_out[31:0]                                    | 12345678        | 00000000     |          |                  | 123      | 5678     |          |
| 🕨 🙀 din(31:0)                                            | 12345679        |              |          | 12345679         |          |          |          |
| 🕨 🍓 n <u>. v.</u> in(19:0)                               | 444c            |              |          | ##(              |          |          |          |
| 🕨 👹 🛛 h in(19:0)                                         | 2198e           |              |          | 2198e            |          |          |          |
| ▶ 🎼 dec_v(15:0)                                          | 444d            |              |          | 444d             |          |          |          |
| 🕨 🙀 dec_h(19:0)                                          | 21985           |              |          | 2198f            |          |          |          |
| ▶ 🎼 s1[15:0]                                             | 0001            |              |          | 0001             |          |          |          |
| ▶ 👹 h0h4_rx(4:0)                                         | 01              |              |          | 01               |          |          |          |
| h5h9_x(40)                                               | 00              |              |          | 00               |          |          |          |
| ▶ 👹 h10h14_rx(4:0)                                       | 00              |              |          | 00               |          |          |          |
| ▶ 🍓 h15h19_rx(4:0)                                       | 00              |              |          | 00               |          |          |          |
|                                                          |                 |              |          |                  |          |          |          |
|                                                          |                 |              |          |                  |          |          |          |
|                                                          |                 |              |          |                  |          |          |          |

Figure.4.7 Simulation result of receiver

Figure.4.8 It consists of all sub modules such as encoder, decoder, CRC checker, error corrector, frame generator and buffer. It fetches the 32-bit tag ID number stored in ROM memory, performs encoding, frame generating, decoding, error corrections and generates fetched 32-bit tag ID as output.

|                                  |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      | 1 |
|----------------------------------|-------------|-------|--------|----|-----|------|---|---|----|------|------|-------|-----|-------|----|---|---|-----|---|---|---|---|------|------|---|
| Name Value                       |             | 15 us |        |    | 2   | Jus  |   |   | 25 | us   |      |       |     | 30 us |    |   |   | 351 | s |   |   |   | 40 u |      | 1 |
| la dk 1                          | Л           | Π     | UΠ     | П  | Т   | Π    | Π |   | Π  | Л    | Π    | Π     | I   | ТП    | π  | Π | Π | П   | П | П |   | 1 | T    | Т    |   |
| Ug freq_div1 1                   |             |       |        |    |     |      |   |   |    |      |      |       |     |       | L  |   |   |     |   |   |   |   |      |      | 1 |
| Ug freq_div2 1                   |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      | ٦ |
| l <mark>a</mark> rst 0           |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |
| ▶ 📑 enable[2:0] 0                |             |       |        |    |     |      |   |   |    |      |      | 0     |     |       |    |   |   |     |   |   |   |   |      |      |   |
| ▶ 📲 decoder_out[31:0] 12345678   |             |       |        |    |     |      |   |   |    |      | 123  | 15678 | 3   |       |    |   |   |     |   |   |   |   |      |      |   |
| ▶ 👹 tx_frame[67:0] 444c2198e123  |             |       |        |    |     |      |   |   |    | 444C | 2196 | e123  | 456 | 78    |    |   |   |     |   |   |   |   |      |      |   |
| ▶ 👹 ffid_tag_no[31:0]   12345678 |             |       |        |    |     |      |   |   |    |      | 123  | 45678 |     |       |    |   |   |     |   |   |   |   |      |      |   |
| Ug lcd_rw 0                      |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |
| 🔓 freq_div 🛛 0                   |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |
| 🕨 👹 count[2:0] 7                 | Xz          | 3     | 4 5    | 6) | 7 0 | 1    | 2 | 3 | 5  | ) 6  | 7    |       | 1   | 2 3   | )4 | 5 | 6 | 7   | 0 | 1 | 2 | 3 | •    | 5 (6 |   |
| 🕨 👹 count1[20] 7                 | <u>)</u> (2 | 3(    | 4 5    | 6) | 7 0 | 1)(1 | 2 | 3 | 1  | 6    | 7    |       | 1   | 2 3   | )đ | 5 | 6 | 7   | ٥ | 1 | 2 | 3 | 1    | 5 6  |   |
| lo Icd_e 0                       |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |
| 1 [cd_5 1                        |             |       |        |    |     |      |   |   | T  |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      | ٦ |
| l <mark>m</mark> lcd_4 1         |             |       |        |    |     |      |   |   | T  |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      | ٦ |
| 1/2 lcd_6 0                      |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |
| 1 Icd_7 0                        |             |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |
| 4.6                              | F           |       |        |    |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      | 1 |
|                                  | X1:         | 43.00 | 0000 1 | JS |     |      |   |   |    |      |      |       |     |       |    |   |   |     |   |   |   |   |      |      |   |

Figure 4.8 Simulation results of Top Module

The table 4.1 shows Area Comparison summary of the DMC Technique. It indicates that DMC Technique performance is better in terms of area when compared with other publications.

Table 4.1 Area Comparison summary of the DMC Technique.

| Name              | Ref. No[13] | Ref. No[14] | This work |
|-------------------|-------------|-------------|-----------|
| No. of Slices     | 75          | 38          | 15        |
| No. of flip-flops | 100         | 50          | 15        |
| No. of LUTs       | 132         | 68          | 14        |
| No. of Logic      | 196         | 50          | 13        |
| No .of IOS        | 72          | 56          | 44        |
| No. of bounded I  | OB 72       | 40          | 44        |
| No. of GCLK       | 1           | 1           | 1         |
| Total             | 584         | 321         | 146       |

Various other parameters such as Delay and Power Summary for DMC Technique are shown in the table 4.2 for various ECC's. This Technique has better performance in terms of power and speed.

Table 4.2 Power and delay comparison summary of the DMC Technique

| Type of ECC used | Slices | flip flops | LUTs | Bounded<br>IO | Delay(ns) | Power   |
|------------------|--------|------------|------|---------------|-----------|---------|
| This work        | 174    | 30         | 96   | 44            | 3.10ns    | 0.5mW   |
| DMC[40]          | NA     | NA         | NA   | NA            | 4.9ns     | 10.8mW  |
| PDS* [41]        | NA     | NA         | NA   | NA            | 18.7ns    | 221.1mW |
| MC [15]          | NA     | NA         | NA   | NA            | 7.1ns     | 24.7mW  |
| Matrix<br>Code   | 164    | 32         | 291  | 96            | 14.548ns  | 0.121W  |
| Hamming<br>Code  | 1350   | 32         | 2682 | 84            | 17.133ns  | 0.163W  |
| PIE/FM0<br>[21]  | NA     | NA         | NA   | NA            | NA        | 1.58mW  |

#### V. CONCLUSION

In this paper, the Decimal Matrix Code for UHF passive RFID tag has been presented. Encoder reuse technique reduced the area overhead of extra circuits. Simulation and synthesis results reveal that our Decimal Matrix Code can complete its function successfully with power consumption of about 0.1 mW, delay is about 3.109 ns.

#### REFERENCES

- [1]. J. Landt, "The history of RFID" Potentials, IEEE, vol. 24, pp. 8-11, 2005.
- [2]. B. Nath, et al., "RFID Technology and Applications," Pervasive Computing, IEEE, vol. 5, pp. 22-24, 2006.
- [3]. R. Weinstein, " RFID: a technical overview and its application to the enterprise," IT Professional, vol. 7, Pp.27-33, 2005.
- [4]. K. Finkenzeller, "RFID Handbook, Fundamentals and Applications in contactless smart cards" Radio Frequency Identifications John Wiley and Sons, Ltd. Publication, vol. Third Edition, 2010.
- [5]. I. Ismail, A. Ibrahim. Modelling and Simulation of Base band Processor for UHF RFID Reader on FPGA International journal of electrical and electronic systems research, vol.6 JUNE 2013.
- [6]. Adam S.W. Man, et. al., "Design and Implementation of a Low-power Basebandsystem for RFID Tag" Circuits and Systems, 2007. ISCAS 2007. IEEE International Symposium on, 2007, pp: 1585-1588.
- [7]. Dingguo Wei, Chun Zhang, Yan Cui, Hong Chen, Zhihua Wang "Design of a Low-cost Low-power Baseband-Processor for UHF RFID Tag with Asynchronous Design Technique" Institute of Microelectronics, T singhua University, Beijing, 100084, PR. China 2012 IEEE.
- [8]. Jing Guo, Liyi Xiao, Member, IEEE, Zhigang Mao, Member, IEEE, and Qiang Zhao" Enhanced Memory Reliability Against Multiple Cell Upsets Using Decimal Matrix Code". IEEE transactions on very large scale Integration (VLSI) systems, vol. 22, no. 1, January 2014.
- [9]. Rodriguez-Rodriguez, J.A. et. al., "Baseband-Processor for a Passive UHF RFID Transponder", Green Circuits and Systems (ICGCS), 2010 International Conference on, 2010, pp: 344-348.
- [10]. Weiwei Shi, et. al., "A 90nm RFID Tag's Base band Processor with Novel PIE Decoder and Uplink Clock Generator", Circuits and Systems (MWSCAS), 2010 3<sup>rd</sup> IEEE International Midwest Symposium on, 2010, pp: 644-647.
- [11]. Roostaie, V. et. al., "A Low Power Baseband Processor for a Dual Mode UHF EPC Gen 2 RFID Tag", Design and Technology of Integrated Systems in Nano scale Era, 2008. DTIS2008. 3rd International Conference on, 2008, pp: 1-5.
- [12]. Shen Jinpeng, Wang Xin'an ,LiuShan Zong Hongqiang, HuangJinfeng, YangXin, Feng

Xiaoxing and GeBinjie "Design and implementation of an ultra-low power passive UHF RFID tag" Key Laboratory of Integrated Microsystems, Peking University Shenzhen Graduate School, Shenzhen 518055, China 2012.

- [13]. C. Argyrides and D. K. Pradhan, "Improved decoding algorithm for high reliable reed muller coding," in Proc. IEEE Int. Syst. On Chip Conf., Sep. 2007, pp. 95–98.
- [14]. NAGA RAMESH KOTTI "Inernational journal of advanced Technology and Innovative Research ISSN 2348–2370 Vol.07,Issue.17, November-2015, Pages: 3343-3349