## **DEVELOPMENT OF THE OFFSET QUADRATURE PHASE SHIFT KEYING MODULATOR FOR ZIGBEE STANDARD ON FPGA**

#### **Rafidah Ahmad, Othman Sidek, Shukri Korakkottil Kunhi Mohd**

IC Design Group, Collaborative Microelectronic Design Excellence Centre (CEDEC), Universiti Sains Malaysia, Engineering Campus 14300 Nibong Tebal, Seberang Perai Selatan, Pulau Pinang, Malaysia Tel:  $+604-5995857$ , Fax:  $+604-5930920$ E-mail : rafidah.ahmad@usm.my

**Abstract**—Zigbee is a standard that defines a set of communication protocols for low data rate short-range wireless networking. It operates primarily in the 2.4 GHz band, which makes the technology easily applicable and readily available worldwide. This paper provides a short overview of the Offset Quadrature Phase Shift Keying (OQPSK) modulator in the digital transmitter based on the Zigbee Standard. The use of Verilog code through Xilinx ISE is presented. The Verilog code is synthesized, simulated, and implemented on a Spartan3E XC3S500E Field Programmable Gate Array (FPGA). The design area of OQPSK modulator obtained is smaller than that of Very-high-speed integrated circuit Hardware Description Language (VHDL) based design. The OQPSK modulator functionality is illustrated through simulations and verified via measurements. The proposed design matches theoretical expectations. The implementation configuration requires approximately 26.1% of slices, 22.7% of flip-flops, and 15.2% of look-up tables (LUTs). With the clock frequency of 2 MHz, the synthesis run time took 93 s.

**Keywords:** Zigbee, OQPSK, Verilog, Xilinx, FPGA

## **1. INTRODUCTION**

Nowadays, increasing attention has been focused on Zigbee, a low data rate, low power, and low cost wireless networking protocol based on the IEEE 802.15.4 standard for Wireless Personal Area Networks (WPANs). The standard specifies that a compliant system will operate in three license-free bands: 868 MHz (20 kbps) for North America, 915 MHz (40 kbps) for Europe, and 2.45 GHz (250 kbps maximum data rate) for worldwide use [1]. The transmission range is 10 to 100 meters based on the environment [2]. The major applications of Zigbee focus on sensor and automatic control, such as military application, industrial control, smart buildings, and environmental monitoring [3]. There are four packet frame types for the Zigbee Standard: data, acknowledgment, Media Access Control (MAC) command, and beacon. The beacon frame is used by a coordinator to transmit beacons. The function of beacons is to synchronize the clock of all the devices within the same network. The data frame is used to transmit data. Meanwhile, the acknowledgement frame is used to confirm successful frame reception [4]. The MAC commands are transmitted using a MAC command frame.

Previously, digital Offset Quadrature Phase Shift Keying (OQPSK) was designed either using Matlab, schematic or Very-high-speed integrated circuit Hardware Description Language (VHDL). For example, Jain et al. [5] developed and simulated the OQPSK modulator for CDMA system using Matlab. However, to the best of the authors knowledge, the modulator was not implemented in his work. Schematic on the other hand is not practical for a complex design because of longer design timeframe. In COM-101 [6], VHDL has been used to design the OQPSK demodulator through Xilinx ISE 4.1. The demodulator was then implemented on Spartan2 XC2S200 FPGA. However,

VHDL makes the instruction process more complex, requiring a larger design area. Hence, VHDL cannot be applied in the development of small size devices. In this paper, Verilog code is used as an alternative design methodology because it is simpler, more time-efficient, and optimal compared with VHDL. Although Li et al. [7] has designed the OQPSK modulator with the similar design method, the modulator has never been implemented.

Here, the code for OQPSK modulator is implemented on Spartan3E family FPGA, which is specifically designed to meet the high-volume and cost-sensitive needs of consumer electronic applications. Device enhancements, combined with advanced 90 nm process technology, deliver more functionality and bandwidth per dollar than was previously possible, setting new standards in the programmable logic industry [8].

This paper is organized as follows. In the second section, an overview of the Zigbee digital transmitter is given, followed by the characteristics of the OQPSK modulator in the third section. The fourth section explains the design methodology. In fifth section, the results and discussion of final simulation and measurement for the OQPSK modulator are presented. Finally, the paper is concluded in the sixth section.

### **2. OVERVIEW OF ZIGBEE TRANSMITTER**

Sixteen channels are available for the 2.4 GHz band applications with ample channel spacing of 5 MHz. The Zigbee standard employs a Direct Sequence Spread Spectrum (DSSS) that uses a digital spreading function representing Pseudo-random Noise (PN) chip sequences [9].

This paper is focused on acknowledgment frame. Figure 1 shows the structure of the acknowledgment frame based on [4,10], which originates from within the MAC sub-layer. This frame is constructed from a MAC Header (MHR) and a MAC Footer (MFR). The MHR contains the MAC Frame Control field and the Direct Sequence Number (DSN), while the MFR is composed of a 16-bit Frame Check Sequence (FCS). Together, the MHR and the MFR form the MAC acknowledgment frame and passes to the Physical (PHY) as the PHY Service Data Unit (PSDU), which then becomes the PHY payload. The PHY payload is prefixed with the Synchronization Header (SHR) containing the Preamble Sequence and the Start of Frame Delimiter (SFD) fields as well as the PHY Header (PHR). The SHR, PHR, and PHY payloads form the PHY packet known as the PHY Protocol Data Unit (PPDU).



Figure 1: Schematic view of the acknowledgment frame and the PHY packet

#### **Development of the Offset Quadrature Phase Shift Keying Modulator 55**

In this paper, the Preamble Sequence contains 32 bits which are at logic '0'. For the SFD, the length is 8 bits with logic '1110 0101' as stated in the Zigbee Standard. The PHR also contains 8 bits in length with logic '1010 0000' [4]. The Frame Control is 16 bits in length with logic '0100 0100 0000 0000'. The Sequence Number logic is '1000 0000'. Finally, the FCS is 16 bits in length and contains the Cyclic Redundancy Check (CRC) algorithm that depends on the MHR. This gives a total of 88 bits for the acknowledgment frame.

Figure 2 shows the block diagram of the proposed Zigbee digital transmitter based on [10] and [11]. Binary data from the PPDU packet is inserted into the CRC block and then to the bitto-symbol block. Then, every 4 bits are mapped into one data symbol. As shown in Table 1 based on [4], the symbol-to-chip block performs the DSSS where each symbol is mapped into a 32-chip PN sequence. The OQPSK modulation is adopted in the 2.4 GHz band.

The fundamental OQPSK method is to sum the in-phase signal with a quadrature phase signal delayed by half a cycle in order to avoid sudden phase shift change [11]. The modulated OQPSK signal then goes to the half-sine pulse shaping stage in order to reduce inter-symbol interference [12]. The resultant signal is transmitted by the Radio Frequency (RF) transmitter.



Figure 2: Detailed block diagram of the proposed Zigbee digital transmitter

## **3. OQPSK MODULATOR**

The OQPSK modulator is an improved type of QPSK [7]. It is created from QPSK by delaying the Q channel by half a symbol from the I channel [13]. This delay reduces the phase shifts the signal goes through at any instant and results in an amplifier-friendly signal [14]. This OQPSK modulator design is created to meet the need for digital channel modulation in the 2.4 GHz band Zigbee transmitter.

At the OQPSK modulator stage, chip sequences representing each data symbol are modulated onto the carrier using OQPSK with half-sine pulse shaping. Even-indexed chips are modulated onto the in-phase (I) carrier and odd-indexed chips are modulated onto the quadrature-phase (Q) carrier. Figure 3 based on [4] shows that, to form the offset between I-phase and Q-phase chip modulation, the Q-phase chips shall be delayed by  $T_c$  with respect to the I-phase chips.  $T_c$  is the inverse of the chip rate. The chip rate is nominally 2 Mchip/s which is 32 times the symbol rate [15].

| Data symbol<br>(decimal) | Data symbol<br>(binary)<br>$(b_0 b_1 b_2 b_3)$ | Chip values<br>$(c_0 c_1  c_{30} c_{31})$ |  |  |  |  |
|--------------------------|------------------------------------------------|-------------------------------------------|--|--|--|--|
| $\mathbf 0$              | 0000                                           | 11011001110000110101001000101110          |  |  |  |  |
| 1                        | 1000                                           | 11101101100111000011010100100010          |  |  |  |  |
| 2                        | 0100                                           | 00101110110110011100001101010010          |  |  |  |  |
| 3                        | 1100                                           | 00100010111011011001110000110101          |  |  |  |  |
| 4                        | 0010                                           | 01010010001011101101100111000011          |  |  |  |  |
| 5                        | 1010                                           | 00110101001000101110110110011100          |  |  |  |  |
| 6                        | 0110                                           | 11000011010100100010111011011001          |  |  |  |  |
| $\tau$                   | 1110                                           | 10011100001101010010001011101101          |  |  |  |  |
| 8                        | 0001                                           | 10001100100101100000011101111011          |  |  |  |  |
| 9                        | 1001                                           | 10111000110010010110000001110111          |  |  |  |  |
| 10                       | 0101                                           | 01111011100011001001011000000111          |  |  |  |  |
| 11                       | 1101                                           | 01110111101110001100100101100000          |  |  |  |  |
| 12                       | 0011                                           | 00000111011110111000110010010110          |  |  |  |  |
| 13                       | 1011                                           | 01100000011101111011100011001001          |  |  |  |  |
| 14                       | 0111                                           | 10010110000001110111101110001100          |  |  |  |  |
| 15                       | 1111                                           | 11001001011000000111011110111000          |  |  |  |  |

Table 1: Symbol to chip mapping using DSSS [4]



Figure 3: OQPSK chip offsets

## **4. DESIGN METHODOLOGY**

The behaviour of OQPSK modulator, which is based on Table 1, was performed with Verilog through Xilinx ISE. The code was then synthesized in order to convert the code to the logic gates and check the design syntax to find any errors [16]. The simulation waveform was presented before the

#### **Development of the Offset Quadrature Phase Shift Keying Modulator 57**

implementation process purposely to ensure that the design's output waveform matches theoretical expectation. After the modulator was implemented onto the Spartan3E FPGA, it was measured using Logic Analyzer, as shown in Figure 4, once again to ensure that the design's output waveform matches the simulation waveform.

The proposed Verilog implementation for OQPSK modulator is best described as below.

1. The input data to this block are totally 704 chips per acknowledgment frame. These chips were obtained from equation (1) [17],

$$
[88 \text{ bits} \div 4 \text{ symbols}] \times 32 \text{ chips} = 704 \text{ chips}
$$
 (1)

The clock frequency is 2 MHz.

- 2. The input chips were divided into the odd and even chips, which were then stored in Q-phase and I-phase registers, respectively.
- 3. The 352 chips from I-phase registers were shifted serially to the output port followed by the 352 chips from Q-phase registers after a half clock cycle, *Tc*.



Figure 4: The measurement setup for OQPSK modulator

Figure 5 shows the schematic of OQPSK modulator. The *clk* is the clock frequency of 2 MHz. Meanwhile, the *data in*, *load mod*, *process start*, *reset mod*, and *shift en* are the input ports. The  $data\_out(0)$  and  $data\_out(1)$  are the output ports for I-phase and Q-phase, respectively.

One part of the Verilog code for the OQPSK modulator is shown in Figure 6. The code was synthesized, simulated, and implemented onto FPGA to verify functionality.

#### **5. RESULTS AND DISCUSSION**

Simulation and measurement were carried out for the OQPSK modulator and the results were compared to verify its functionality. The logic values of 88 bits are based on the Zigbee Standard.



Figure 5: The structure of OQPSK modulator



Figure 6: The Verilog code for OQPSK modulator

#### **5.1. Simulation Waveform**

As shown in Figure 7, when only *shift en* is at logic '1', the *data out* is available within 352 500 ns, including the delay of  $T_c$  which occurred on odd chips. Logic values at both  $data\_out(0)$  and  $data\_out(1)$  are based on chip values contained in Table 1.

By referring to Figure 8, at 355 250 ns, the  $data\_out(1)$  (Q-phase chips) is delayed by  $T_c=500$ ns with respect to the  $data\_out(0)$  (I-phase chips). The timing for each chip is  $2T_c = 1\mu s$ .

From the final simulation waveform, output data of the OQPSK modulator is shown to match theoretical expectation.

|                                |   | 355 250 ns<br>707 750 ns<br>352 500 ns                                                  |
|--------------------------------|---|-----------------------------------------------------------------------------------------|
| <b>End Time:</b><br>1.3e+06 ns |   | 704750 ns<br>478750 ns<br>422250 ns<br>535250 ns<br>591750 ns<br>648250 ns<br>365750 ns |
| $\mathbf{M}$ cik               | Û |                                                                                         |
| <b>M</b> data_in               |   |                                                                                         |
| <b>M</b> load_mod              | 0 |                                                                                         |
| <b>Jul</b> process_start 0     |   |                                                                                         |
| <b>M</b> reset_mod             | 0 |                                                                                         |
| <b>M</b> shift_en              |   |                                                                                         |
| <b>El aX</b> data_out(1:0)     | 0 |                                                                                         |
| M data_out[1]                  | 0 |                                                                                         |
| <b>JI</b> data_out[0]          | 0 |                                                                                         |

Figure 7: The simulation waveform of output data

|                                                 |   |                     |   |  | 355 250 ns |       |           |                                           |  |          |           |  |
|-------------------------------------------------|---|---------------------|---|--|------------|-------|-----------|-------------------------------------------|--|----------|-----------|--|
| <b>End Time:</b><br>$1.3e + 06$ ns              |   | 350750 ns 354750 ns |   |  |            |       | 358750 ns |                                           |  |          | 362750 ns |  |
| $\mathbf{H}$ clk                                | 0 |                     |   |  |            |       |           |                                           |  |          |           |  |
| <b>B_n</b> data_in                              | 1 |                     |   |  |            |       |           |                                           |  |          |           |  |
| <b>M</b> load_mod                               | 0 |                     |   |  |            |       |           |                                           |  |          |           |  |
| <b>Jul</b> process_start                        | 0 |                     |   |  |            |       |           |                                           |  |          |           |  |
| <b>BJI</b> reset_mod                            | 0 |                     |   |  |            |       |           |                                           |  |          |           |  |
| <b>BJI</b> shift_en                             | 1 |                     |   |  |            |       |           |                                           |  |          |           |  |
| aX data_out[1:0]<br>$\qquad \qquad \qquad \Box$ | 0 |                     | O |  |            | X3X 2 |           | $\sqrt{2}$ (3) $\chi$ <sub>2</sub> $\chi$ |  | $\bf{0}$ |           |  |
| <b>30</b> data_out[1]                           | 0 |                     |   |  |            |       |           |                                           |  |          |           |  |
| <b>M</b> data_out[0]                            | 0 |                     |   |  |            |       |           |                                           |  |          |           |  |

Figure 8: The simulation waveform of  $data\_out(0)$  and  $data\_out(1)$ 

## **5.2. Measurement Result**

Figure 9 shows that when only *shift\_en* is at logic '1', the *data\_out* is available within 352 497 ns from M1 to M2, including the delay of *T<sup>c</sup>* which occurred on odd chips. Logic values at *Data1* are referred to  $data\_out(0)$ , and  $Data2$  is referred to  $data\_out(1)$ . Both  $Data1$  and  $Data2$  are similar to the output data in simulation waveform.

From Figure 10, it can be seen that *Data2* (Q-phase chips) is delayed by  $T_c \approx 500$  ns from M3 to M4, with respect to *Data1* (I-phase chips). The waveform also shows that the minimum output delay after clock is 1.667 ns while the maximum output delay after clock is 18.333 ns. The timing for each chip is approximately 1*µ*s.

| Bus/Signal      | Simple Trigger               | 340.2 us<br>۲<br>$\blacksquare$ | 440.2 us | 540.2 us | 690.2 us       |
|-----------------|------------------------------|---------------------------------|----------|----------|----------------|
| $\Box$ Clock1   | ¥<br>0                       | M1                              |          |          | M <sub>2</sub> |
| Time            |                              |                                 |          |          |                |
| $\Box$ Data in  | X<br>¥                       |                                 |          | 1        |                |
| load_mod        | X<br>₹                       |                                 |          | 0        |                |
| reset_mod       | X<br>¥                       | 0                               |          |          |                |
| $\Box$ shift_en | X<br>¥                       |                                 |          |          | $\mathbf{0}$   |
| process_stari   | X<br>š                       |                                 |          | 0        |                |
| Data 1          | $\times$<br>¥                |                                 |          |          | 0              |
| $\Box$ Data 2   | $\overline{\mathsf{x}}$<br>¥ |                                 |          |          | 0              |

Figure 9: The measurement waveform of output data



Figure 10: The measurement waveform of *Data1* and *Data2*

The measurement result shows that output data of the OQPSK modulator match the final simulation waveform. However, the measurement waveform shows that a small delay occurred at *Data1* and *Data2* after the rising edge of a clock. The delay is most probably caused by pin and net delays on Spartan3E FPGA. As the modulator was implemented with a speed grade of 5, the specifications obtained after implementation is summarized in Table 2. Specifications for the VHDL-based design methodology are included for comparison. The table shows that the configuration required about 1 216 slices out of 4 656 (26.1%), 2 115 flip flops out of 9 312 (22.7%), and  $\overline{1}$  415 look-up tables (LUTs) out of 9 312 (15.2%). The average connection delay for this design was 1.630 ns. All signals were completely routed within 93 s with 194 MB CPU memory

## **Development of the Offset Quadrature Phase Shift Keying Modulator 61**

usage. These results show that the total of slices, flip-flops, and LUTs for Verilog-based OQPSK modulator decreased by 73%, 40%, and 62% respectively as compared to implementation of VHDLbased OQPSK demodulator. Therefore, it is proven that the design area of OQPSK modulator with Verilog-based design method is smaller than to VHDL-based method.



Table 2: Comparison between the proposed design method and the VHDL-based design method

(\*Note: The VHDL-based design involved OQPSK demodulator.)

# **6. CONCLUSION**

This paper describes the development of an OQPSK modulator as part of the digital transmitter for a 2.4 GHz band Zigbee Standard on FPGA. This modulator is used to sum the in-phase signal with a quadrature-phase signal delayed by half a cycle in order to avoid sudden phase shift change. Verilog code is used to characterize the OQPSK behavior, which is then simulated, synthesized, and successfully downloaded on Spartan3E FPGA. The measurement result shows that functionality of the OQPSK modulator matches theoretical expectation. Furthermore, the Verilog-based OQPSK modulator contributes to a smaller design area of FPGA device, compared to VHDL-based OQPSK demodulator. The design has been verified with the frequency of 2 MHz.

# **ACKNOWLEDGMENT**

The authors would like to acknowledge the financial support provided by Universiti Sains Malaysia Short Term Grant no. 304/PCEDEC/60310018 for this project.

# **REFERENCES**

- 1. Adis, V. Citing Internet sources URL http://www.cs.chalmers.se/~tsigas/Courses/ DCDSeminar/Files/diovoad\%20Zigbee.pdf, May 2006.
- 2. Lee, J. S., Su, Y. W. and Shen, C. C. "A Comparative Study of Wireless Protocols: Bluetooth, UWB, Zigbee and WiFi". *In Proceedings of the 33rd Annual Conference of the IEEE Industrial Electronics Society (IECON)* , 46–51. Taipei, Taiwan, 2007.
- 3. Zhou, Y., Yang, X., Gou, X., Zhou, M. and Wang, L. "A Design of Greenhouse Monitoring & Control System Based on Zigbee Wireless Sensor Network". *In Proceedings of the International Conference on Wireless Communications, Networking & Mobile Computing* , 2563–2567, 2007.
- 4. IEEE Std.802.15.4 Part 15.4: Wireless Medium Access Control (MAC) and Physical Layer (PHY) Specifications for Low-Rate Wireless Personal Area Networks (LR-WPANs), *C* IEEE, 2006.
- 5. Jain, K., Nagrath, E, Jaiswal, A., Mishra, S. and Shukla, S. "Performance of OQPSK as a Modulation Scheme using AWGN Channel for CDMA System". *VSRD International Journal of Electrical, Electronics & Communication Engineering* , Vol. 1(2), 72–82, 2011.
- 6. COM-101, BPSK/QPSK/OQPSK Demodulator VHDL Source Code Overview. Citing Internet sources URL http://comblock.com/download.html, 2004.
- 7. Li, F., Ke, X. and Li, Q. "Design and Implement of OQPSK Modulator Based on FPGA". *In Proceedings of the Eighth International Conference on Electronic Measurement and Instruments* , 929–933. 2007.
- 8. Xilinx. Spartan3E FPGA Family: Complete Data Sheet, 2006.
- 9. Oualkadi, A. E., Andendorpe, L. V. and Flandre, D. "System-level Analysis of O-QPSK Transceiver for 2.4 GHz band IEEE 802.15.4 Zigbee Standard". *In Proceedings of the 14th International Conference on Mixed Design* , 469–474. Ciechocinek, Poland, 2007.
- 10. IEEE Std.802.15.4. IEEE standard for wireless medium access control (MAC) and physical layer (PHY) specifications for low-rate wireless personal area networks (LR-WPANs),  $\widehat{\phi}$  *CIEEE*, 2003.
- 11. Wang, C. C., Huang, J. M., Lee, L. H., Wang, S. H. and Li, C. P. Citing Internet sources URL http://ieeexplore.ieee.org/iel5/4145986/4099325/04146217.pdf, 2007.
- 12. John, N., Anthony, C., and Gary, L. "CMOS RFIC Architectures for IEEE 802.15.4 Networks". *Cadence Design Systems* . Columbia, Maryland, 2003.
- 13. Proakis, J. *Digital Communications* , McGraw-Hill, 2000.
- 14. Xiuge, Y., Jenshan, L., Kenneth, K. O. and Joe, B. "Design and Analysis of a Low-Power Constant Envelope". *In Proceedings of the Radio and Wireless Conference* , 363–366, 2004.
- 15. Kluge, W., Poegel, F., Roller, H., Lange, M., Ferchland, T., Dathe, L. and Eggert, D. "A Fully Integrated 2.4 GHz IEEE 802.15.4-Compliant Transceiver for Zigbee Applications". *IEEE Journal of Solid-State Circuits* , 2767–2775, 2006.
- 16. Ahmad, R., Sidek, O. and Mohd, S. K. K. "Development of Bit-to-Chip Block for Zigbee Transmitter on FPGA". *In Proceedings of International Conference on Computer and Electrical Engineering (ICCEE 2009)* , 492–496, 2009.
- 17. Ahmad, R., Sidek, O., Wan Hassin, W. M. H., Mohd, S. K. K. and Mohamad, F. Development of a Verilog-based Pulse-shaping Block for Zigbee Applications. *In Proceedings of International Conference on Modeling, Simulation and Control (ICMSC 2010)* , 65–68, 2010.