# Design and FPGA Implementation of an Adaptive Demodulator

Sandeep Mukthavaram and Joseph B. Evans

Information & Telecommunication Technology Center
University of Kansas

**HPEC '99** 

24 September 1999





# Introduction

## Field Programmable Gate Arrays (FPGAs) -

- Re-configurability ideally suited for adaptive applications. Circuits can be loaded and deleted as required.
- Parallelism required for high throughput computation involved with real time processing of signals.

## **Adaptive Signal Processing Systems -**

- Will need to operate in rapidly changing environments.
- Require re-programmable hardware to implement adaptive algorithms.



The Idea Exploit re-configurability and parallelism offered by FPGAs to build adaptive signal processing systems.





# **Presentation Overview**

- Motivation
- Automatic Modulation Recognition (AMR)
  - Need for AMR
  - Existing strategies
  - Novel algorithm of AMR
- Design Flow for FPGA Synthesis
- Design and FPGA Implementation of PSK and FSK demodulators
- Reconfigurable Platform
  - WILDFORCE
  - Adaptive Demodulation
- Testing and Results
- Conclusions and Future work



# **Motivation**

- To suitably adapt to changing requirements, control strategies targeted at selecting and tuning of signal processing algorithms need to be developed.
- Changing requirements are identified as, to be able to support processing of communication signal of different typologies that emit from different sources.
- Universal receivers do exist that can switch between resident demodulators based on the input from the modulation recognizer.
- The proposed approach is to dynamically reconfigure the same FPGA to perform the necessary demodulation while monitoring for any changes in the input.





# **Automatic Modulation Recognition**

## Why do we need AMR?

- Civilian Applications
  - Signal conformation, interference identification, spectrum management, monitoring non-licensed transmitters.
- Defense Applications
  - Electronic warfare, surveillance, threat detection, threat analysis, warning, target acquisition and jamming.
  - Example: COMINT (Communications Intelligence)





# **Automatic Modulation Recognition**

# **Existing Strategies -**

- Decision theoretic approaches
  - Probability and hypotheses testing are employed
  - Statistical moments, Likelihood functions, autoregressive spectrum modeling are popular methods.
- Statistical Pattern Recognition
  - Pre-processing of signals
  - Key feature extraction (instantaneous amplitude, frequency and phase, spectral processing)
  - Pattern Recognition
    - Training phase
    - Testing phase
  - Artificial Neural Networks





#### **Automatic Modulation Recognition Novel Algorithm of AMR PSK ABS** Threshold **Modulated OPSK Averaging** +**Spike Filter** Counter **BPSK** >Unit Delay **RST Decision** Clock **Time Period = Decision interval RST Zero Cross** Counter Counter **BFSK** Zero **FSK Threshold** Cross **Detector Modulations Supported:** PSK - {BPSK, QPSK} FSK - BFSK



# **Automatic Modulation Recognition**

## FPGA Implementation details of AMR

- Specifications
  - Data rate: 100 kbps
  - Carrier: 500 kHz BPSK, QPSK

400 kHz - Mark

600 kHz - Space

**BFSK** 

- PSK Threshold: 2 mV, for input of 500 mV P-P
- FSK Threshold: 9
- Decision Period: 2048 clock cycles, 8 MHz clock

#### FPGA Implementation Details:

• Parttype: 4085 xla HQ240 -09

• CLB Usage: 588 of 3136 (18%)

• Max. Clock: 26.4 MHz

• Sampling : 8 MHz















# **BPSK Demodulator**

# **FPGA** Implementation details

- 72.5 MHz IF signal at the input is sub-sampled using an 8 MHz clock and the image at the 500 kHz is used for rest of the processing. The information content is retained.
- All filters implemented as Finite Impulse Response.
- Multipliers in the filters reduced to Look Up Tables (LUTs).

#### FPGA Implementation Details:

• Parttype: 4025E HQ240 -4 (Xilinx).

• CLB Usage : 898 of 1024 (87%)

• Max. Clock: 10.07 MHz

• Sampling : 8 MHz







# **QPSK Demodulator**

# **FPGA Implementation Details**

- Most of the blocks designed for BPSK re-used.
- Hilbert Transformer used for the 90° phase shift, is implemented as a FIR structure with anti-symmetric coefficients.
- Design is partitioned across three FPGA chips for better timing and performance.



# **QPSK Demodulator**

# **FPGA Implementation Details**

#### **IOFPGA:**

Modules: Lower Channel, Parallel-to-Serial, Differential Decoder.

Parttype: 4013 PG223 -5 (Xilinx).

CLB Usage: 538 of 576 (92%).

Max. Clock: 10.06 MHz

### FPGA1:

Modules: Carrier Recovery, Hilbert

Transformer

Parttype: 4025E HQ240 -4 (Xilinx).

CLB Usage: 835 of 1024 (81%).

Max. Clock: 9.41 MHz

#### FPGA2:

Modules: Upper Channel.

Parttype: 4025E HQ240 -4 (Xilinx).

CLB Usage: 530 of 1024 (52%).

Max. Clock: 9.34 MHz

#### **Summary:**

CLB Usage: 2003 CLBs

Max. Clock: 9.34 MHz

Sampling: 8 MHz

APTIX MP3A Prototyping board.





# **BFSK Demodulator**

# **Block Diagram**



#### **Specifications:**

• Data rate: 100 kbps

• Carrier: 400 kHz - Mark

600 kHz - Space

## FPGA Implementation Details:

• Parttype: 4013 PG223 -5 (Xilinx).

• CLB Usage : 4 of 576 (1%)

• Max. Clock: 63.4 MHz

• Sampling : 8 MHz





#### **Re-configurable Platform WILDFORCE** Architecture WILDFORCE BOARD **FIFO** FIFO '1' FIFO '0' **FIFO '4' Interface** 512 x 36 512 x 36 512 x 36 CROSS BAR Logic Core **CPE '0'** Logic Logic Logic Logic DSP/Memory Core Core Core Core DPMC '0' PE '2' PE '4 PE '1' PE '3' **PCI SWITCH** DSP/Memory DSP/Memory DSP/Memory DSP/Memory Bus **DPMC '2' DPMC '3'** DPMC '4' DPMC '1' **EXTERNAL SIMD** interrupts CONNECTOR I/O CARD



# **Re-configurable Platform**

# **WILDFORCE Software Hierarchy**











#### **Testing Test Setup for Evaluation of PSK Demodulators APTIX MP 3A BOARD** FPGA1 FPGA2 XC4025E XC4025E **HQ240-4 HQ240-4** Rx\_Data FPIC1 FPIC2 Analog BPF **PSK** @ 70 MHz Bit Signal 20 dB IOFPGA **Error STEL-9231** A/D XC4013 Tx Data Rate **PSK** PG223-5 Converter White Tester Sym\_Clk Modulator Gaussian Noise **Analog** Sample Clock **Noise Front End IF Signal Generator** 8 MHz Generator



# Results

# How good are the PSK demodulators?









# Results













-2.5

-3.5

-5.5

-6.5



10.5

11

11.5

# Results

## How good is the carrier recovery scheme used?

- The carrier recovery scheme employed for the BPSK demodulation could tolerate a carrier in the band 450-550 kHz, which is about 100 kHz. This can be attributed to the bandwidth of the bandpass filter in the carrier recovery circuit.
- The QPSK receiver had a tolerance of 50 kHz drift in the carrier frequency centered at 500 kHz.



# Results

# Noise Tolerance of the AMR algorithm

- The proposed algorithm of AMR was tested to measure its performance in presence of additive white Gaussian noise.
- AMR algorithm could tolerate noise levels as low as a SNR of 20 dB when all the modulations BPSK, QPSK, and BFSK are present.
- The algorithm could detect the modulation correctly for BFSK with noise levels as low as 5 dB of SNR.
- Noise tolerance for modulations BPSK and QPSK remain at 20 dB. (Depends on how good the filtering is !)





# **Conclusions**

- Proposed and implemented a novel algorithm of automatic modulation recognition for detecting BPSK, QPSK and BFSK.
- Designed and implemented the individual demodulators -BPSK, QPSK and BFSK on FPGAs.
- The AMR algorithm along with the demodulators are integrated into an adaptive demodulator.
- The capabilities offered by the re-configurable platform have been demonstrated which can be a promising choice for a more robust signal processing or communication system.



