# Designing of N-Bit Linear Feedback Shift Register For Communication

Naincy Soni<sup>1</sup>, Dr. Nidhi Tiwari<sup>2</sup>

<sup>1</sup> Dept of Electronics and Communication
<sup>2</sup>Assitant Professor, Dept of Electronics and Communication
<sup>1, 2</sup> SAGE University, Indore, India

Abstract- This paper has studied the notion of PN sequence and design of linear feedback shift register as applicable to spread spectrum code division multiple access technique. Maximum length sequence arrangements were presented, and utilized as a prologue to some difficult strategies for PN code generation with the assistance of LFSR. In linear feedback shift register, the feedback is used to modification on every clock cycle. In this paper we have implemented n-bit LFSR and achieved maximum frequency upto 1300 MHz, which can be used in SS-CDMA. Different parameters are discussed and compared with few existing research papers. Overall parameters were obtained with the help of Xilinx 12.1i by using VHDL.

*Keywords*- Shift Registers, LFSR, PN Sequence, CDMA, and VHDL

## I. INTRODUCTION

Considerable interest has developed during the past two decades in the binary feedback shift registers. These devices are capable of generating cyclic sequences possessing statistical properties which closely approximate those of binary random noise. Such, apparently random, but deterministic, sequences may be used, therefore, in place of this noise) and the results which are thus obtained are much more accurate than those obtained using binary noise. The ease and simplicity in generating and processing the sequences are further responsible for this development.

The arena of mobile communication is presently developing at very uncommon rate. This development provoked to a limited extent by the increasing rate, broadband communication, has prompted the requirements for high determination, broadband mobile measurement hardware. The wireless communication structure is one of most significant method in the entire existence of media transmission which has enhanced human development and mankind by uniting business and network. A pseudo noise sequence (PN sequence) is assigned to each user in the spread spectrum code division multiple access schemes for the purpose of grouping and dispreading. In this way PN sequence is viewed as the

core of CDMA/SS-CDMA systems. The maximal length pseudo noise sequence is best depicted sequence whose length is same with its period. Linear feedback shift register i.e. LFSR is used to generate multiple PN sequence. In this shift register feedback is provided by essential feedback taps. By VLSI technology, the implementation of LFSR circuit can be used in less delayed communication system designs.

The objective of this work is to evaluation of n-bit Linear Feedback Shift Register using memory element. Also designing the LFSR for the application of CDMA, where PN sequence is multiply with input message to add the security while transmitting the codeword into wide range of frequency. Bascially CDMA works in the frequency range of 900 MHz to 1.9 GHz so the objective of this thesis is to design and implement LFSR for this frequency range..

## II. LITERATURE REVIEW

Wherever**Mishra Shivshankar et al. [1]**,in this paper author suggested and implemented the configurable linear feedback shift register. They assess the results in terms of logic, memory and speed requirements using Xilinx ISE 9.2i tool. Their targeted device for implementation is Vertex-4 FPGA board. The implemented 8 bit and 16 bit CLFSR completes the output sequence cycle in 51000 ns and 13107000 ns. Author also suggested various applications of CLFSR like PN sequence generator, Gold code generator and CRC generator.

R Saraswathi et al. [2], in this paper author described the design and implementation of linear feedback shift register (LFSR) for low power test pattern generator. They modified the existing design of linear feedback shift register by utilizing transition controllers. Their simulation and results are achieved through Altera Quartus 16.0. They compared their results for power consumption and Number of test pattern generated.

**TejasThubrikar et al. [3],** in this research manuscript author designed and implemented 32 bit low power test pattern generator using linear feedback shift register. Their whole

Page | 490 www.ijsart.com

design is implemented in Xilinx ISE 13.1i using VHDL language. By using extra combinational circuit in the existing design of LSFR they achieved 50% reduction in power consumption. Also they attained less number of slice register used and less number of LUT's.

RoshniJamgade et al. [4], in this paper the author suggested new method for designing of linear feedback shift register. They used vedic multiplication which is the oldest method for multiplication using vedic formulas. Author suggested the application of linear feedback shift register for generation of PN sequence which is used in CDMA for multiplication with original sequence of message to add the security in transmission over a wide frequency. Area and delay analysis is done in this existing work.

**DebarshiDatta et al.** [5], this paper suggested the design and implementation of multibit linear feedback shift register to generate PN sequence codes which are very useful in CDMA. They designed the circuit using pseudo random number generator (PRNG) in HDL language. Their targeted device for implementation is Vertex-4 FPGA board for implementing 8 bit, 16 bit and 32 bit LFSR. They compared the results for various parameters like number of slice registers, occupied slices, and number of input output blocks, delay and power consumed.

Table 1: Comparison of various parameters of some research papers

| _      |                           |                  |                     |                           |               |                           |
|--------|---------------------------|------------------|---------------------|---------------------------|---------------|---------------------------|
| N<br>o | Name of<br>the Author     |                  | No of<br>Bits       | Parameter                 | FPGA<br>Used  | Tool<br>Used              |
| 1      | Mishra<br>Shivshanka<br>f | 2<br>0<br>1<br>6 | \$/16               | Timing                    | Vertex<br>4   | Xdin<br>x                 |
| 2      | R.<br>Saraswatki          | 2<br>0<br>1<br>7 | 8                   | Power                     |               | Alter<br>a<br>Quart<br>is |
| 3      | TejasThubr<br>škar        | 2<br>0<br>1<br>7 | 8                   | Power                     |               | Xdin<br>x                 |
| 4      | RoshniJam<br>gade         | 0 1 5            | 8                   | Power                     | Virtex<br>7   | Xdin<br>x                 |
| 5      | DebarshDu<br>tta          | 2<br>0<br>1<br>7 | 8/16                | Delay                     | Sparta<br>n 6 | Xdin<br>x                 |
| 6      | Proposed                  | 2<br>0<br>2<br>0 | 8, 16, 32<br>and 64 | Power/Delay/<br>Frequency | Artix<br>7    | Xdin<br>x                 |

# III. METHODOLOGY

There are many applications of linear feedback shift registers, and it is commonly used in mobile communications where pseudo random sequence is required. These are the basic blocks of many circuits like PN sequence generator, gold code producer which is used in spread spectrum code division multiple access techniques. Linear feedback shift registers are extensively used for binary counters to generate random number sequences. Maximum time the generated sequence is pseudorandom in nature. These patterns may repeat over period, as longer the shift registers. This repetition is depends on the number of taps present in the registers. For large pattern generation, the size of hardware may be increased. Conservatively, for the older architectures of FPGA, flip flops were used. LFSR sequences are generated through  $2^N - 1$ state, where N is the number of flip-flops/taps in the LFSR. After every edge of clock, the data of flip flop is shifted right. The feedback path is provided from previous register to the left most register through an XOR or XNOR gate. Value of 0's is illegal for XOR feedback path similarly value of 1's is illegal for XNOR feedback path. These illegal states may cause the shift register to present in its present state [13].

A 4-bit LFSR sequences generated through (2<sup>4</sup> - 1) is having 15 states (the state 1111 is in the illegal state) from the feedback taps 4 and 3. At the same time, a 4 bit binary counter may generate the sequence by 2<sup>4</sup> i.e. 16 states without any illegal stages. Still linear feedback shift register are faster than normal counter because they don't have carry signal. Linear feedback shift register are the substitute of normal binary counters in perilous applications where the counted sequence is not that much important. Linear feedback shift register are also used as pseudo random sequence generators. These are the basic blocks of many circuits like PN sequence generator, gold code producer which is used in spread spectrum code division multiple access techniques. The tap sequence is responsible to affect the bits positions of next bits.

The n bit LFSR whose maximum feedback polynomial is represented as follows:

Table 2: Generator polynomial for LFSR

| Number of Bits | Generator         |
|----------------|-------------------|
|                | Polynomial        |
| 4              | x*+x*+1           |
| 8              | x°+x°+x°+x*+1     |
| 16             | x'0+x'3+x'3+x*+1  |
| 32             | x**+x**+x+1       |
| 64             | xe4+xe3+xe1+xe0+1 |

The general block diagram for 4, 8, 16 and 32 bit is shown as below:

Page | 491 www.ijsart.com



Figure 1: General block diagram of LFSR

## IV. SIMULATION AND RESULT

All the experiment analysis is done by 14.1i in Vertex device family. The significant benefit of this software is low-memory with high-speed analysis of any complex circuit. Simulation and synthesize of Linear Feedback Shift Register circuit may be improved by Xilinx design suit 14.1i Vertex device family series and device.

The RTL view, simulation waveform, schematic layout and device utilization summary for 4 bit, 8 bit, 16 bit and 32 bit is shown as below:



Figure 2: RTL view of 4 bit LFSR

| Name                | Value    |       |      | 50 ns |      | 10   | 0 ns |      | 150 ns |      | 200  | ns   |      | 250 | ns |      | 3    | 00 r |
|---------------------|----------|-------|------|-------|------|------|------|------|--------|------|------|------|------|-----|----|------|------|------|
| V <sub>0</sub> r_dk | 1        |       |      |       |      |      |      |      |        |      |      |      |      |     |    |      |      |      |
| w_lfsr_data[3:0]    | 0100     | (0001 | 0011 | 0111  | 1110 | 1101 | 1011 | 0110 | 1100   | 1001 | 0010 | 0101 | 1010 | 01  | 00 | 1000 | 0000 | D)   |
| ₩_lfsr_done         | 0        |       |      |       |      |      |      |      |        |      | 1    |      |      |     |    |      |      |      |
| 🖟 c_num_bits        | 100      |       |      |       |      |      |      |      | 100    |      | İ    |      |      |     |    |      |      |      |
| 🖟 c_clk_period      | 20000 ps |       |      |       |      |      |      | 20   | 000 ps |      |      |      |      | Ī   |    |      |      |      |
|                     |          |       |      |       |      |      |      |      |        |      |      |      |      |     |    |      |      |      |

| Name               | Value    | 0 ns  |      | 20 ns | liiii | 40 ns | liiii | 60 ns   |      | 80 ns | liiii | 100 ns |       | 120 ns |
|--------------------|----------|-------|------|-------|-------|-------|-------|---------|------|-------|-------|--------|-------|--------|
| lo r_dk            | 1        |       |      |       |       |       |       |         |      |       |       |        |       |        |
| • 🤻 w_lfsr_data[7: | 00000001 | 00000 | 0000 | 0001  | 0000  | 0011  | 0000  | 0111    | 0000 | 1111  | 0001  | 1110   | 00111 | 101    |
| ₩_lfsr_done        | 0        |       |      |       |       |       |       |         |      |       |       |        |       |        |
| 🖟 c_num_bits       | 1000     |       |      |       |       |       |       | 1000    |      |       |       |        |       |        |
| 🖟 c_clk_period     | 20000 ps |       |      |       |       |       |       | 0000 ps |      |       |       |        |       |        |
|                    |          |       |      |       |       |       |       |         |      |       |       |        |       |        |

| Name              | Value       | 11 | 11,718,430 ns | 11,718,440 ns | 11,718,450 ns | 11,718,460 ns | 11,718,470 ns | 11,718,480 ns |
|-------------------|-------------|----|---------------|---------------|---------------|---------------|---------------|---------------|
| lk r_clk          | 1           |    |               |               |               |               |               |               |
| 🔰 w_lfsr_data[15: | 00101010110 | 1  | 00001010      | 10110111      | 00010101      | 01101111      | 0010101       | 11011111      |
| ₩_lfsr_done       | 0           |    |               |               |               |               |               |               |
| 🖟 c_num_bits      | 10000       |    |               |               | 10000         |               |               |               |
| 🖟 c_dk_period     | 20000 ps    |    |               |               | 20000         | os            |               |               |
|                   |             |    |               |               |               |               |               |               |

| ame               | Value       |          | 4,628,445 ns     | 4,628,450 ns | 4,628,455 ns      | 4,628,460 ns     | 4,628,465 ns | 4,628,470 ns |
|-------------------|-------------|----------|------------------|--------------|-------------------|------------------|--------------|--------------|
| l₀ r_dk           | 0           |          |                  |              |                   |                  |              |              |
| ₩_lfsr_data[31:0] | 11011010111 | 11011010 | 1101010100011000 | 010101       | 10110101111010101 | 0001100010101010 | (0110101     | 101010100    |
| ₩_lfsr_done       | 0           |          |                  |              |                   |                  |              |              |
| 🖟 c_num_bits      | 100000      |          |                  |              | 100000            |                  |              |              |
| 🖟 c_clk_period    | 15000 ps    |          |                  |              | 15000 ps          |                  |              |              |
|                   |             |          |                  |              |                   |                  |              |              |
|                   |             |          |                  |              |                   |                  |              |              |

Figure 3: Simulated waveform for 4, 8, 16, 32 and 64 bit LFSR

|     |         | PN:  | Sequ | esce  | Tes | t Patte | m  | for 4 bit | 5   |     |
|-----|---------|------|------|-------|-----|---------|----|-----------|-----|-----|
| 0   | 1       | 3    |      | 7     |     | 14      |    | 13        | 11  | 6   |
| 12  | 9       | 2    |      | 5     |     | 10      | Г  | 4         | 8   | 0   |
| 1   | 3       | 7    | 1    | 14    |     | 11      |    | 13        | 6   | 12  |
| 9   | 9 2 5 1 |      | 10   |       | 4   | Г       | 8  | 0         | 1   |     |
|     |         | PN S | eque | nce I | est | Patte   | rs | for 8 bi  | its |     |
| 1   | 3       | 7    | 7    | 15    | ,   | 30      |    | 61        | 122 | 244 |
| 232 | 208     | 16   | 51   | 67    |     | 135     | ,  | 14        | 28  | 57  |
| 114 | 229     | 20   | 03   | 15    | 1   | 47      |    | 95        | 191 | 127 |
| 254 | 253     | 25   | 51   | 24    | 7   | 238     |    | 220       | 184 | 113 |

| PN Sequence Test Pattern for 16 bits |   |       |         |         |           |          |       |       |  |  |  |  |
|--------------------------------------|---|-------|---------|---------|-----------|----------|-------|-------|--|--|--|--|
| 1                                    | Т | 3     | 7       | 15      | 30        | 60       | 120   | 240   |  |  |  |  |
| 481                                  |   | 963   | 1927    | 3855    | 7710      | 15421    | 30842 | 61636 |  |  |  |  |
| 5783                                 | 6 | 50136 | 34736   | 6 3936  | 7873      | 15746    | 31492 | 62985 |  |  |  |  |
| 6043                                 | 5 | 55335 | 45133   | 5 2473  | 2 4946    | 5 33394  | 1252  | 2505  |  |  |  |  |
|                                      |   |       |         |         |           |          |       |       |  |  |  |  |
|                                      |   |       | PN Sequ | ence Te | st Patter | n for 32 | bits  |       |  |  |  |  |
| 1                                    |   | 2     | 4       | 9       | 18        | 36       | 73    | 146   |  |  |  |  |
| 292                                  | Τ | 585   | 1170    | 2340    | 4681      | 9362     | 18724 | 37449 |  |  |  |  |
| 7489                                 |   | 1497  | 2995    | 59918   | 11983     | 23967    | 47934 | 95869 |  |  |  |  |

Page | 492 www.ijsart.com

**Table 3: Device utilization summary** 

| Synthesis<br>Parameter           | 4 bit   | 8 bit       | 16 bit      | 32 bit  |
|----------------------------------|---------|-------------|-------------|---------|
| Number Slice<br>Registers        | 4       | 8           | 16          | 32      |
| Number of Slice                  | 5       | 11          | 22          | 43      |
| Number of<br>occupied Slice      | 2       | 4           | 6           | 13      |
| Number of LUT<br>Flin Flon nairs | 5       | 11          | 22          | 43      |
| Number of IOBs                   | 12      | 20          | 36          | 68      |
| Max Freq (MHz)                   | 1169.45 | 964.<br>971 | 964.9<br>71 | 964.971 |
| Time Delay (ns)                  | 0.855   | 1.03        | 1.036       | 1.036   |
| Power (mW)                       | 83      | 100         | 152         | 246     |

This paper basically deals with the design of linear feedback shift register using XOR gates. Above device utilization summary mentioned in table 3 shows the parameters used by the design. The following comparison table 4 shows the result of proposed LFSR with existing design:

Table 4: Comparison between different LFSR architectures

| LFSR<br>Architecture | Numbe<br>r of Bit | Numbe<br>r of<br>Slices<br>(Area) | Max.<br>Frequenc<br>y in MHz<br>(Speed) | Time<br>Dela<br>y in<br>ns |
|----------------------|-------------------|-----------------------------------|-----------------------------------------|----------------------------|
| DebarshiDutta<br>[5] | 32                | 32                                | 663.46                                  | 1.507                      |
| A. K. Panda [9]      | 32                | 18                                | 137.532                                 | 7.27                       |
| S. Hathwalia<br>[10] | 32                | 32                                | 476.872                                 | 2.09                       |
| K. C. Sekhar<br>[11] | 32                | 9                                 | 153.045                                 | 6.534                      |
| Proposed<br>Design   | 32                | 32                                | 1291.849                                | 1.036                      |

#### V. CONCLUSION

To full fill the objective of this work, we have implemented linear feedback shift register using xor gates for 4 bit, 8 bit, 16 bit and 32 bit. Eventually, in this paper we have structured a LFSR which is used to generate PN sequence in various applications like Counters, CDMA, cryptography, test pattern generation and digital broadcasting etc. Our proposed design has very less output delay as compare to other designs. In the previous research work maximum frequency achieved is 664 MHz, and our proposed design will work up to 1300 MHz which can be used in CDMA.

#### REFERENCES

- [1] R. Saraswathi, R.Manikandan, "Design of LFSR for low Power Test Pattern Generator", IEEE NetACT 2017
- [2] Shivshankar Mishra, Ram RakshaTripathi and Devendra Kr. Tripathi, "Implementation of Configurable Linear Feedback Shift Register in VHDL", International Conference on Emerging Trends in Electrical, Electronics and Sustainable Energy Systems (ICETEESES–16).
- [3] TejasThubrikaret. al. "Design and Implementation of Low Power Test Pattern Generator Using Low Transitions LFSR" International Conference on Communication and Signal Processing, IEEE 2017
- [4] RoshniJamgadeet. al. "Design and Implementation of PN Sequence Generator using Vedic Multiplication" International Conference on Advances in Computer Engineering and Applications (ICACEA) IEEE 2015
- [5] DebarshiDuttaet. al. "Design and Implementation of Multibit LFSR on FPGA to Generate Pseudorandom Sequence Number" Devices for Integrated Circuit (DevIC), IEEE 2017
- [6] Katti, R.S. Srinivasan, S.K., "Efficient hardware implementation of a new pseudo-random bit sequence generator," IEEE International Symposium on Circuits and Systems, 2009.
- [7] K. Panda Amit, P. Rajput, B Shukla, "Design of Multi Bit LFSR PNRG and Performance comparison on FPGA using VHDL," International Journal of Advances in Engineering & Technology (IJAET), Mar 2012, Vol. 3, Issue 1, pp. 566-571.
- [8] A. K. Panda, P. Rajput and B. Shukla, "FPGA Implementation of 8, 16 and 32 Bit LFSR with Maximum Length Feedback Polynomial using VHDL," IEEE Int. Conference on Communication Systems and Network Technologies, DOI 10.1109, 2012.
- [9] S. Hathwalia and M. Yadav, "Design and Analysis of a 32 Bit Linear Feedback Shift Register Using VHDL", Int. Journal of Engineering Research and Applications, ISSN: 2248-9622, Vol. 4, Issue 6(Version 6), pp.99-102, June 2014.

Page | 493 www.ijsart.com