# A Study on the Advanced RFID System in Railway using the Parallel CRC Technique # 철도에서 병렬 순환 잉여 기법을 이용한 차세대 무선인식 시스템에 관한 연구 Tai-Kyu Kang<sup>1</sup> · Jae-Ho Lee<sup>2</sup> · Seok-Kyun Shin<sup>2</sup> · Jae-Hoon Lee<sup>2</sup> · Key-Seo Lee<sup>3</sup> 강태규 · 이재호 · 신석균 · 이재훈 · 이기서 #### Abstract This paper has presented the parallel cyclic redundancy check (CRC) technique that performs CRC computation in parallel superior to the conventional CRC technique that processes data bits serially. Also, it has showed that the implemented parallel CRC circuit has been successfully applied to the inductively coupled passive RFID system working at a frequency of 13.56MHz in order to process the detection of logical faults more fast and the system has been verified experimentally. In comparison with previous works, the proposed RFID system using the parallel CRC technique has been shown to reduce the latency and increase the data processing rates about 15% in the results. Therefore, it seems reasonable to conclude that the parallel CRC realization in the RFID system offers a means of maintaining the integrity of data in the high speed RFID system. Keywords: RFID (Radio Frequency IDentification), 13.56MHz, CRC, Parallel CRC # 1. Introduction In communication systems, data integrity is ensured by the addition of a frame check sequence (FCS) at the end of a message so it can be checked at its destination for correct transmission. CRC can be employed to generate the FCS at the source of the message, and check the integrity of the entire message (data plus FCS) at the destination. Current RFID systems employ CRC to validate message integrity. CRC calculation can be performed in hardware or Isoftware. The common hardware solution is the linear feedback shift register (LFSR), which is a simple bit-serial architecture for both encoding and decoding messages. The bit-serial approach lacks efficiency for processing a parallel data stream, since every n-bit data word needs n-clock cycles to calculate the check sum. This approach is not efficient at high bit rates. The basic bit-serial algorithm can be accelerated by parallel processing a number of bits. Such a case demands the parallel CRC solution. The parallel CRC implementation can perform the necessary logic operations much faster than conventional CRC implementation and allows one circuit to be shared by several transmission lines. This paper is structured as follows. In Section II, gives a short summary of the RFID technology as the background information of RFID systems. In Section III, illustrates the key elements of the parallel CRC technique and derives the logic equations of parallel CRC technique and presents the parallel CRC circuit. In Section IV, designs the inductively coupled passive RFID system using the implemented parallel CRC circuit. Finally, in Section V, evaluates the experimental results and presents the conclusion of this paper as well as future works. <sup>1</sup> 광운대학교 제어계측공학과 석사과정 <sup>2</sup> 광운대학교 제어계측공학과 박사과정 <sup>3</sup> 광운대학교 제어계측공학과 정교수 ## 2. RFID System RFID denotes Radio-Frequency IDentification. It provides a quick, flexible and reliable way to electronically detect, track and control a variety of items. RFID systems use radio transmissions to send energy to a transponder which in turn emits a unique identification code back to data collection reader linked to an information management system. RFID systems effectively utilize two separate antennas one on the transponder, and one on the reader to accomplish the task of data transfer by radio signals back to the data management system. The data collected from the transponder can be sent either directly to a host computer through standard interfaces, or it can be stored in a portable reader and up-loaded later to a computer for data processing. An RFID system is always made up of two components: The transponder, which is located on the object to be identified. The interrogator or reader, which, depending upon the design and the technology used, may be a read or write/read device. A reader typically contains a radio frequency module, a control unit and a coupling element to the transponder. In addition, many readers are fitted with an additional interface to enable them to forward the data received to another system. On the reader side, modulator modulates the binary sequences from the memory unit into analog waveform, here proper coding (Manchester) and modulation (ASK, FSK) schemes will be selected by the modulator. The oscillator adds a carrier frequency to the analog waveform and the amplifier will amplify the signals and send them out through the antenna. The transponder, Fig. 1. The main Components of RFID Systems which represents the actual data-carrying device of an RFID system, normally consists of a coupling element and an electronic microchip. On the transponder side works almost the same as on the reader side. The clock module provides clocks to the digital circuits and the power module provides enough energy to drive the circuit. Demodulators on both sides will convert the transmitted signal to binary sequences for the digital circuits. When the transponder, which does not usually posses its own voltage supply (battery), is not within the interrogation zone of a reader it is totally passive. The transponder is only activated when it is within the interrogation zone of a reader. The power required to activate the transponder is supplied to the transponder through the coupling unit (contactless), as are the timing pulse and data. #### 3. Parallel CRC Parallel Cyclic Redundancy Check (CRC) technique implementations simultaneously process multiple bits of data in parallel, increasing the data processing rate, with only a relatively small increase in the hardware complexity of serial CRC implementations that process data bits serially. The bit-serial approach lacks efficiency for processing a parallel data stream, since every n bit data word needs n clock cycles to calculate the checksum. Such a case demands a parallel CRC circuit solution. Parallel CRC hardware is attractive because, by processing the message in blocks of w bits each, it is possible to reach a speed-up of w with respect to the time needed by the serial implementation. Starting from the circuit represented in [Fig 3], the parallel CRC has been implemented. In the following, we assume that the degree of polynomial generator (m) and the length of the message to be processed (k) are both Fig. 2. An example of the Euro Balise System multiples of the number of bits to be processed in parallel (w). This is typical in data transmission where a message consists of many bytes and the polynomial generator, as desired parallelism, consists of a few nibbles. In the final circuit that we will obtain, the sequence $S_1$ plus the zeros are sent to the circuit in blocks of w bits each. After $\frac{k+m}{w}$ clock periods, the FFs outputs give the desired FCS. From linear systems theory, we know that a discrete time, time-invariant linear system can be expressed as follows. $$\begin{cases} X(i+1) = FX(i) + GU(i) \\ Y(i) = HX(i) + JU(i) \end{cases}$$ (1) where X is the state of the system, U the input, and Y the output. We use F, G, H, J to denote matrices and use X, Y, and U to denote column vectors. The solution of the first equation of the system (1) is: $$X(i) = F^{i}X(0) + [F^{i-1}G...FGG][U(0)...U(i-1)]^{T}$$ (2) We can apply (2) to the LFSR circuit [Fig 3]. From this consideration, the solution of the system (1) (expressed by (2)) is valid even if we replace multiplication and addition with the AND and XOR operators, respectively. We use $\oplus$ to denote the XOR operation and the symbol $\cdot$ to denote bitwise AND. In order to point out that the AND and XOR operators must be also used in the product of matrices, we will denote their product by $\otimes$ . Let us consider the circuit shown in [Fig 3]. It is just a discrete-time, time-invariant linear system for which the input U(i) is the ith bit of the input sequence; the state i represents the FFs output and the vector i coincides with i i.e., i and i are the identity and zero matrices, respectively. Matrix i and i are chosen according to the equations of serial LFSR, So, we have: $$X = [x_{m-1} \dots x_1 x_0]^T$$ $$H = I_m$$ The identity matrix of size $m \times m$ where $p_i$ are the bits of the divisor P (i.e., the coefficients of the generator polynomial). When i coincides with w, the solution derived from (2) with substitution of the operators is: $$X(w) = F^{w} \otimes X(0)[0...0|d(0)...d(w-1)]^{T}$$ (3) where X(0) is the initial state of the FFs. Considering that the system is time-invariant, we obtain a recursive formula: $$X' = F^w \otimes X \oplus D \tag{4}$$ where, for clarity, we have indicated with X and X, respectively, the next state and the present state of the system, and $D = [d_{m-1}...d_1d_0]^T$ assumes the following values: $[0...0|b_0...b_{w-1}]$ , $[0...0|b_w...b_{2w-1}]^T$ , etc., where $b_i$ are the bits of the sequence $S_1$ followed by a sequence of m zeros. This result implies that it is possible to calculate the m bits of the FCS by sending the k+m bits of the message $S_1$ plus the zeros, in blocks of w bits each. So, after $\frac{k+m}{w}$ clock periods, X is the desired FCS. Now it is important to evaluate the matrix $F^w$ . There are several options, but it is easy to show that the matrix can be constructed recursively when i ranges from 2 to w: $$F^{i} = \begin{bmatrix} F^{i-1} & \begin{bmatrix} p_{m-1} \\ \cdots \\ p_{1} \\ p_{0} \end{bmatrix} & \text{the first } m-1 \\ \text{columns of } F^{i-1} \end{bmatrix}$$ (5) From (5), we can obtain $F^w$ when $F^m$ is already available. If we indicate with P' the vector $[p_{m-1...}p_1p_0]^T$ , we have: $$F^{w} = \left[ F^{w-1} \otimes P' \dots F \otimes P' P' \middle| \frac{I_{m-w}}{0} \right]$$ (6) where $I_{m-w}$ is the identical matrix of order m-w. Furthermore, we have: $$F^{m} = [F^{m-1} \otimes P' | \dots | F \otimes P' | P']$$ $$(7)$$ So, $F^w$ may be obtained from $F^m$ as follows: The first w columns of $F^w$ are the last w columns of $F^m$ . The 4 한국철도학회논문집 제8권 제1호 2005년 upper right part of $F^{w}$ is $I_{m-w}$ and the lower right part must be filled with zeros. # 4. Experiment As the [Fig 5] indicates, the proposed RFID system using the parallel CRC technique is made of the following parts: the microcontroller, the Programmable Logic Device (PLD), the reader and the transponder. The microcontroller has been used to control the reader with the antenna and matching circuit and to perform the data exchange between the reader and the external application software. The parallel CRC circuit has been implemented by VHDL codes in the PLD according to the ISO/IEC 13239 (polynomial: $x^{16} + x^{12} + x^5 + 1 = 0x8408$ , reverse, start value 0xFF, 1's complement). The inductively coupled passive RFID system has been operated in the 13.56MHz ISM band with a range of up to 1m according to the ISO standard 15693 that describes the method of functioning and operating parameters of contactless vicinity coupling smart cards. Fig. 3. One of the possible LFSR architectures Fig. 4. Parallel CRC architecture Having clarified the objectives of the experiment, the procedure will be explained in sequence. First, the data communications between the reader and the transponder have been performed by the ISO 15693 standards protocols and the conventional CRC codes implemented in the firmware. As the result, [Fig 6] indicates the waveform of the transponder ID string. Second, we have complied the VHDL codes concerning the presented parallel CRC circuit and simulated them using the Altera's Maxplus+II. What has to be noticed is that it is focused on implementing the parallel CRC circuit using the VHDL codes in the PLD because there are many dissertations that have already proved that the parallel CRC technique is much faster than the conventional CRC technique in a view of speed. Third, the conventional CRC codes in the firmware of the RFID system had been eliminated and the PLD implementing the parallel CRC circuit has been connected to the RFID system to apply the parallel CRC technique instead of the conventional CRC technique. Finally, the data transferred between the reader and the transponder has been successfully observed in the external application software. Also, Fig. 5. RFID System using the Parallel CRC Fig. 6. Waveform of the Transponder String ID the time of the data communications has been measured and compared approximately between the existing RFID system and the proposed RFID system by using the timer and counter of the external application program on the limited conditions. [Fig 9] shows comparatively the line graph of the time of processing the data regarding the transponder ID between the existing RFID system and the proposed RFID system. #### 5. Conclusions and Future Works The presented parallel CRC technique has been successfully implemented by the VHDL codes in the PLD and verified experimentally in the simulation using the Fig. 7. Simulation of sending the data in the parallel CRC circuit Fig 8. Simulation of receiving the data in the parallel CRC circuit Fig. 9. The line graph of the time of processing the data Altera's MAX+plus II software tool. Furthermore, the implemented parallel CRC circuit has been applied to the inductively coupled passive RFID system working at a frequency of 13.56MHz and the data communications between the reader and the transponder have been correctly observed in the external application program. Although the speed of data exchanged in the RFID system has not been investigated precisely, the RFID system using the parallel CRC technique has been shown to reduce the latency and increase the data processing rates about 15% in the result of [Fig 9]. Therefore, it seems reasonable to conclude that the parallel CRC realization in the RFID system offers a means of maintaining the integrity of data in the high speed RFID system. A further direction of this study will be to provide more evidence for this result in detail and, from now on, a more prescriptive approach will be needed to solve the mentioned issue. Finally, the result of this paper will change the direction of the entire study of the RFID system. # Acknowledgement 본 논문의 연구는 2004년도 광운대학교 교내연구비 에 의 하여 수행되었습니다. ## References - 1. W.W.Peterson and D.T. Brown, "Cyclic Codes for Error Detection", Proc. IRE, Jan. 1961. - 2. Tanenebaum, "Computer Networks", Prentice Hall, 1981. - Stallings, "Data and Computer Communications", Prentice Hall, 2000. - T.V. Ramabadran and S.S. Gaitonde, "A Tutorial on CRC Computations", IEEE, Aug. 1988. - N.R. Saxena and E.J. McCluskey, "Analysis of Checksums, Extended Precision Checksums and Cyclic Redundancy Check s", IEEE Trans. Computer, July. 1990. - K. Finkenzeller, "RFID Handbook Second Edition", John Wiley and Sons Ltd., 2003. - Min-Soo, Kang, "A Study on Prevention of Collision and Data Loss of the RFID system using a Full-Length Instruction Code Method", Korean society for railway, Oct. 2004. - Sun Ki Baek, Key Seo Lee, "A Study on Location Tracking and Identification Using RFID System Within Building", Korean society for railway, Oct. 2003. - Shang Moon Yun, Key Seo Lee, "A Study on the Multiple Identification using Slotted ALOHA Method in a RFID system", Korean society for railway, Oct. 2003.