# Com Block

# COM-1827SOFT\_SOQPSK Modem VHDL source code overview / IP core

# Overview

The COM-1827SOFT\_SOQPSK is a SOQPSK modulator and demodulator- written in generic VHDL.

The entire **VHDL source code** is deliverable. It is portable to a variety of FPGA targets.

### Key features and performance:

- SOQPSK is a spectrum-efficient constant envelope modulation well suited for operation through power amplifiers near saturation.
- Flexible programmable features:
  - Symbol rate up to  $f_{clk}/4$ , where  $f_{clk}$  is the processing clock frequency.
  - o SOQPSK-MIL and SOQPSK-TG
- Excellent BER performance using trellis decoding (SOVA). 4-bit soft-decision demodulator output for best FEC decoder performance.
- Performance:
  - Near theoretical BER vs Eb/No
  - ±50ppm symbol timing tracking
  - Carrier frequency acquisition: ±10% of symbol rate at the threshold
  - Acquisition threshold < 2dB Eb/No

- Provided with IP core:
  - VHDL source code
  - Matlab .m file for generating stimulus files for VHDL simulation of the demodulator and for end-to-end BER performance analysis at various signal to noise ratios
  - VHDL testbenches (back-to-back modem or stimulus file input)
  - PRBS11 test sequence generator, AWGN noise generator, BER tester

# Configuration

### **Run-time configuration parameters**

The user can set and modify the following controls at run-time through the top level component interface:

| Modulator Parameters | Configuration                                                                                                                |
|----------------------|------------------------------------------------------------------------------------------------------------------------------|
| SYMBOL_RATE          | symbol rate expressed as symbol_rate/ <b>f</b> <sub>clk</sub> * 2^32                                                         |
| MODULATION_INDEX     | modulation index h.<br>unsigned fixed-point<br>format 4.12.                                                                  |
|                      | h is always 0.5 (0x0800)<br>for SOQPSK                                                                                       |
| GAIN                 | output amplitude scaling factor. 15-bit unsigned                                                                             |
| CENTER_FREQ          | modulated signal center<br>frequency. Expressed as<br>fc/ f <sub>elk</sub> * 2^32                                            |
| BURST_LENGTH         | A synchronization word is<br>inserted periodically<br>between frames (to<br>resolve any phase<br>ambiguity at the receiver). |
|                      | This just includes the data field, not the 32-bit preamble.                                                                  |
|                      | Constraint:<br>BURST_LENGTH is a<br>multiple of 8 bits.                                                                      |
|                      | composite limit:<br>preamble+sync+BURST_<br>LENGTH < 8191                                                                    |
| CONTROL              | bits 2:0 modulation order<br>M (always 3 for<br>SOQPSK)                                                                      |
|                      | bits 7:4 frequency shaping filter selection                                                                                  |
|                      | 5 = SOQPSK-MIL                                                                                                               |
|                      | 6 = SOQPSK-TG                                                                                                                |
|                      | bits 9:8 test mode: 00 no<br>test, 01 = PRBS11, 11 =<br>unmodulated carrier                                                  |
|                      | bit 10: always '1' to enable sync word insertion                                                                             |
|                      | bit 11: spectrum<br>inversion. invert Q. on (1)<br>or off (0)                                                                |

| <b>Receiver Parameters</b> | Configuration           |
|----------------------------|-------------------------|
| AGC_RESPONSE               | Adjust the AGC response |
| —                          | time. approximately     |

|                          | log2(NSymbols).                                                                                                                                     |  |
|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|--|
| RECEIVER_CENTER_<br>FREQ | nominal (i.e. expected)<br>center frequency.<br>Expressed as<br>fc/demodulator processing<br>clock * 2^32                                           |  |
|                          | This frequency is<br>subtracted from the input<br>signal center frequency.                                                                          |  |
|                          | Add -fclk/4 when used in<br>conjunction with IF<br>undersampling.                                                                                   |  |
| CIC_R                    | CIC Decimation ratio.<br>The output sampling rate<br>is thus fclk/R                                                                                 |  |
|                          | 1 to bypass. 0 is illegal,<br>otherwise, nominal range<br>is 1 to 16384.                                                                            |  |
|                          | Usage: be careful not to<br>decimate too much as the<br>CIC decimation filter is<br>not very sharp and thus<br>can distort the modulated<br>signal. |  |
|                          | Rule of thumb: the CIC<br>filter output sampling rate<br>should be >= 4 samples<br>per symbol.                                                      |  |
| NOMINAL_SYMBOL_<br>RATE  | fsymbol rate / fclk * 2^32<br>= nominal symbol rate                                                                                                 |  |
| M_SEL                    | modulation order M<br>selection. Always 3 for<br>SOQPSK                                                                                             |  |
|                          | 0: M=2                                                                                                                                              |  |
| FILT_SEL                 | Filter selection:<br>5 = SOQPSK-MIL<br>6 = SOQPSK-TG                                                                                                |  |
| MODULATION_INDEX         | modulation index h.<br>unsigned fixed-point<br>format 4.12.                                                                                         |  |
|                          | h is always 0.5 (0x8000)<br>for SOQPSK                                                                                                              |  |
| FRAME_LENGTH             | Frame length, including<br>payload + 32-bit sync<br>word                                                                                            |  |
| DEMOD_CONTROL            | bit 0: spectrum inversion<br>enabled(1)/disabled(0)<br>bit 1: AFC<br>enabled(1)/disabled(0).<br>bit 2: forces ACC                                   |  |
|                          |                                                                                                                                                     |  |

| bit 3: sync word detection<br>enabled (1)/disabled(0)<br>REQUIRED WITH<br>SOQPSK<br>MODULATIONS                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit 4: FFT<br>enabled(1)/disabled(0) to<br>increase the frequency<br>acquisition range                                                               |
| bit 5: enable(1)/disable(0)<br>sync word removal at<br>output. Generally remove,<br>except when another sync<br>detection follows after the<br>demod |

### I/Os

# General

#### CLK: input

The synchronous clock. The user must provide a global clock (use BUFG). The CLK timing period must be constrained in the .xdc file associated with the project.

#### SYNC\_RESET: input

Synchronous reset. The reset MUST be exercised at least once to initialize the internal variables. It must be exercised whenever a control parameter is changed.

### Modulator

|                                                  | COM1827_TX CPM MO                                                                                                                      | DULATOR                                        | ]        |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|----------|
| $\rightarrow$                                    | CLK<br>SYNC_RESET                                                                                                                      | DATA_I_OUT(15:0)<br>DATA_Q_OUT(15:0)           |          |
| $\rightarrow \rightarrow \rightarrow \leftarrow$ | TX_DATA(7:0)<br>TX_DATA_SAMPLE_CLK<br>TX_SOF INPUT<br>TX_CTS BITS                                                                      | TX_EN_OUT<br>MODULATED<br>BASEBAND<br>WAVEFORM |          |
| <b>^ ^ ^ ^ ^ </b>                                | SYMBOL_RATE(31:0)<br>MODULATION_INDEX(15:0)<br>GAIN(15:0)<br>CENTER_FREQUENCY(31:0)<br>BURST_LENGTH(12:0)<br>CONTROL(15:0)<br>CONTROLS | SATURATION<br>SYMBOL_CLKx4_OUT<br>MONITORING   | <b>)</b> |

**TX\_DATA(7:0)**: Input data byte. The MSb is sent first.

#### TX\_DATA\_SAMPLE\_CLK: input.

1 CLK-wide pulse indicating that TX\_DATA is valid.

**TX\_SOF**: optional input Start Of Frame. 1 CLKwide pulse. The SOF is aligned with **TX\_DATA\_SAMPLE\_CLK**.

### TX\_CTS: output.

Clear-To-Send flow control. '1' indicates that the modulator is ready to accept another input byte. Thanks to an input elastic buffer, the data source is allowed to send a few more bytes after TX\_CTS goes low.



Modulator input flow control example

**DATA\_I/Q\_OUT(15:0)**: Modulated baseband output samples (I = in-phase, Q = quadrature). One output sample every clock. Format: 2's complement (signed)



**TX\_EN\_OUT**: goes low to turn off an external power amplifier when the modulator is not receiving any input data.

### Receiver

| <b>≻</b> →   | COM1827_RX CPM RECEIVER<br>CLK                                                                                                                                                                                                           |               |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| <b>* * *</b> | ADC_DATA_I_IN(13:0)<br>ADC_DATA_Q_IN(13:0)<br>ADC_SAMPLE_CLK_IN                                                                                                                                                                          |               |
| <<br><       | AGC_DAC(11:0) AGC DAC<br>AGC_DAC_SAMPLE_CLK DATA_OUT(3:0)<br>SAMPLE_CLK DEMOD DATA                                                                                                                                                       | $\rightarrow$ |
| ****         | AGC_RESPONSE(4:0)<br>RECEIVER_CENTER_FREQ(31:0)<br>CIC_R(15:0)<br>NOMINAL_SYMBOL_RATE(31:0)<br>FILT_SEL(3:))<br>CARRIER_FREQUENCY_ERROR<br>MODULATION_INDEX(15:0)<br>FRAME_LENGTH(12:0)<br>DEMOD_CONTROL(15:0)<br>CONTROLS<br>MONITORING | <b>~~~~~</b>  |

**ADC\_DATA\_I/Q\_IN(13:0)**: input samples from one or two external ADCs. (one in the case of IF undersampling, two for near-zero frequency complex inputs). If the ADCs have fewer than 14bit precision, align the most significant bit with ADC\_DATA\_IN(13). Format: 2's complement (signed).

AGC\_DAC(11:0): output to an external DAC to control an external AGC. Read when AGC\_DAC\_SAMPLE\_CLK is '1'

**DATA\_OUT(3:0)**: soft-decision output. The demodulated bit is bit 3. The three lower bits indicate the level of confidence: "0000" for a solid '0', "1111" for a solid '1', "1000" for a '1' barely above the thresold.

# Design considerations



Coherent demodulator block diagram

# Frequency pulse generation

An FIR filter shapes the frequency pulses. The FIR coefficients are stored in a lookup table, sampled at 4 samples/symbol. See CPM\_FILTERSx4.vhd. The table is large enough to store multiple frequency pulse shapes: rectangular pulse for MSK, Gaussian pulse for GMSK, raised cosine for PCM/FM, etc.

The Matlab program /matlab/siggen\_fsk1.m is used to generate the FIR coefficients.

# Performance

# BER vs Eb/No

The plot below shows near-theoretical performance for the SOQPSK demodulator without error correction.



Test condition: +50ppm symbol timing error, 30deg carrier phase error

# **Transmitted spectrum**



SOQPSK-MIL



### Latency

The latency between received signal and demodulated bit output is approximately 20 bits.

# Software Licensing

This software is supplied under the following key licensing terms:

- 1. A nonexclusive, nontransferable license to use the VHDL source code internally, and
- 2. An unlimited, royalty-free, nonexclusive transferable license to make and use products incorporating the licensed materials, solely in bit stream format, on a worldwide basis.

The complete VHDL/IP Software License Agreement can be downloaded from http://www.comblock.com/download/softwarelicense.pdf

# Portability

The VHDL source code is written in generic VHDL and thus can be ported FPGAs from various vendors. See the limitation below.

# **Configuration Management**

The current software revision is 2a.

| Directory | Contents                                                                                                                                                |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| /doc      | Specifications, user manual, implementation documents                                                                                                   |
| /src      | .vhd source code,.pkg packages, .xdc<br>constraint files (Xilinx)<br>One component per file.                                                            |
| /sim      | VHDL test benches                                                                                                                                       |
| /matlab   | Matlab .m file for generating stimulus files<br>for VHDL simulation and for end-to-end<br>BER performance analysis at various signal<br>to noise ratios |
| /bin      | .bit configuration files (for use with<br>ComBlock COM-1800 FPGA development<br>platform)                                                               |

Project files:

Xilinx Vivado v2020 project file: project\_1.xpr tcl file

# VHDL development environment

The VHDL software was developed using the following development environment:

(a) Xilinx Vivado 2020 for synthesis, place and route and VHDL simulation

The entire project fits easily within a Xilinx Artix7-100T. Therefore, the project can be processed using the free Xilinx WebPack tools.

# **Device Utilization Summary**

The modulator size is fixed (not parameterized).

| Device: Xilinx Artix7-100T |      |                                |
|----------------------------|------|--------------------------------|
| Modulator                  |      | % of Xilinx<br>Artix7-<br>100T |
| Registers                  | 1868 | 1%                             |
| LUTs                       | 2078 | 3%                             |
| Block RAM/FIFO             | 10   | 7%                             |
| DSP48                      | 11   | 4%                             |
| GCLKs                      | 1    | 3.1%                           |

The receiver size is fixed (not parameterized).

| Receiver<br>4-bit soft-quantization |       | % of Xilinx<br>Artix7-<br>100T |
|-------------------------------------|-------|--------------------------------|
| Registers                           | 9587  | 7%                             |
| LUTs                                | 11522 | 18%                            |
| Block RAM/FIFO                      | 9     | 6%                             |
| DSP48                               | 61    | 25%                            |
| GCLKs                               | 3     | 9%                             |

# Clock and decoding speed

The entire design uses a single global clock CLK. Typical maximum clock frequencies for various FPGA families are listed below:

| Device family                     | Modulator | Demodulator |
|-----------------------------------|-----------|-------------|
| Xilinx Artix 7 -1 speed grade     | 160 MHz   | 150 MHz     |
| Xilinx Kintex-7 -2<br>speed grade |           |             |

# Ready-to-use Hardware

The COM-1827SOFT was developed on, and therefore ready to use on the following commercial off-the-shelf hardware platform:

#### **FPGA development platform**

<u>COM-1800</u> FPGA (XC7A100T) + ARM + DDR3 SODIMM socket + GbE LAN development platform

# VHDL components overview

### Modulator top level

| 😑 🙀 COM1827_TX_001 - COM1827_TX - Behavioral (src\BURST_CPM_MOD\com1827_tx.vhd)                    |
|----------------------------------------------------------------------------------------------------|
| 😑 🙀 Inst_LFSR11P - LFSR11P - behavior (src\BURST_CPM_MOD\lfsr11p\lfsr11p.\rfsr10)                  |
| 🔚 🔚 LFSR11PROM_001 - LFSR11PROM - Behavioral (src\BURST_CPM_MOD\lfsr11p\fsr11p\fsr11p\rom.vhd)     |
| BURST_TX_001 - BURST_TX - Behavioral (src\BURST_CPM_MOD\burst_tx.vhd)                              |
| 🖶 强 ELASTIC_BUFFER_NRAMB2_001 - ELASTIC_BUFFER_NRAMB2 - behavioral (src\elastic_buffer_nramb2.vhd) |
| 🔚 🙀 BRAM_DP2_001 - BRAM_DP2 - Behavioral (src\com-5402 TCP server 007n\src\bram_dp2.vhd)           |
| 🐵 🔚 ELASTIC_BUFFER_NRAMB2_002 - ELASTIC_BUFFER_NRAMB2 - behavioral (src\elastic_buffer_nramb2.vhd) |
| 😑 🐚 ROM_FIL1_001 - ROM_FIL1 - behavioral (src\BURST_CPM_MOD\rom_fil1.vhd)                          |
| CPM_FILTERSx4_001 - CPM_FILTERSx4 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx4.vhd)               |
| Wa CPM_FILTERSx4_002 - CPM_FILTERSx4 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx4.vhd)            |
| CPM_FILTERSx4_003 - CPM_FILTERSx4 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx4.vhd)               |
| CPM_FILTERSx4_004 - CPM_FILTERSx4 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx4.vhd)               |
| CPM_FILTERSx8_001 - CPM_FILTERSx8 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx8.vhd)               |
| CPM_FILTERSx8_002 - CPM_FILTERSx8 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx8.vhd)               |
| Wall CPM_FILTERSx8_003 - CPM_FILTERSx8 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx8.vhd)          |
| CPM_FILTERSx8_004 - CPM_FILTERSx8 - Behavioral (src\BURST_CPM_MOD\cpm_filtersx8.vhd)               |
| SIN_COS001 - SIGNED_SIN_COS_TBL3 - BEHAVIOR (src\signed_sin_cos_tbl3.vhd)                          |
| - 🔛 SIM2OUTFILE_002 - SIM2OUTFILE - Behavioral (sim\sim2outfile.vhd)                               |
| POWER_MEASUREMENT_001 - POWER_MEASUREMENT - behavior (src\BURST_CPM_MOD\power_measurement.vhd)     |
| 🙀 IMULT18X18SIGNED_001 - MULT18X18SIGNED - BEHAVIOR (src\mult18x18signed.vhd)                      |
| 😥 🙀 AWGN_001 - AWGN - behavior (src\AWGN\src\awgn.vhd)                                             |

*COM1827\_TX.vhd* generates complex baseband continuous phase-modulated samples from byte-size input data.

The *BURST\_TX.vhd* component stores input data in an elastic input buffer, then packs input bits into symbols (1,2,3 bits/symbol) at the specified symbol rate. It also stops the transmitter when the input elastic buffer is empty.

*BRAM\_DP2.vhd* is a generic dual-port memory, used as input and output elastic buffers. Memory is inferred (no Xilinx primitive is used).

*ROM\_FIL1.vhd* implements an FIR filter to shape the frequency pulses. The FIR filter coefficients for various modulation schemes (Gaussian, raised cosine, etc) are stored in the *CPM\_FILTERSx4.vhd* ROM.

*SIGNED\_SIN\_COS\_TBL3.vhd* stores sine and cosine functions in ROM. It is used to convert phase to complex I/Q baseband output samples.

*COM1827\_TOP.vhd*: is mostly a use example when the SOQPSK modem is implemented on a ComBlock COM-1800 FPGA development platform. Please note that this top component can't be simulated as it makes many references to other components outside the scope of the modem proper (TCP stack, turbo codec, etc)

Note for Xilinx Vivado: when creating the project, the file priority order is unimportant, except for the three packages below which must be placed with a higher priority order:



# **Receiver top level**

The receiver is comprised of two high-level components:

RECEIVER1.vhd performs non modulationspecific tasks such as AGC, DC bias removal, frequency translation to baseband, anti-aliasing filtering and decimation.



CPM DEMOD.vhd performs the continuous phase demodulation, including carrier tracking (for coherent demodulation), symbol timing tracking, AGC, matched filtering and trellis decoding.



- 🖮 强 MF\_001 CPM\_MF Behavioral (src\CPM\_DEMOD\cpm\_mf.vhd)
- MF\_COEFFS\_GEN\_002 CPM\_PHASEx4 Behavioral (src\CPM\_DEMOD\cpm\_phasex4.vhd) SIN\_COS\_GEN\_002 SIGNED\_SIN\_COS\_TBL3 BEHAVIOR (src\signed\_sin\_cos\_tbl3.vhd)

- Control of the second sec
- BRAM\_DP2\_001 BRAM\_DP2 Behavioral (src\com-7003\src\bram\_dp2.vhd)
   GPM\_VA\_PMU\_001 CPM\_VA\_PMU behavioral (src\CPM\_DEMOD\VA\cpm\_va\_pmu.vhd)
- Control Control

- AFC2\_001 - AFC2 - behavioral (src\CPM\_DEMOD\afc2.vhd) CT 003 - CARRIER TRACKING - behavioral (src\CPM\_DEMOD\carrier\_tracking.vhd)
- □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □
   □

### Ancillary components

H,

LFSR11P.vhd is a pseudo-random sequence generator used for test purposes. It generates a PRBS11 test sequence commonly used for bit error rate testing at the receiving end of a transmission channel.

BER2.vhd is a bit error rate tester expecting to receive a PRBS11 test sequence. It synchronizes with the received bit stream and count errors over a 80,000 bit window.

#### MATCHED FILTER4x8 001 - MATCHED FILTER4x8 - behavioral (src\BER2\matched filter4x8.vhd) MATCHED\_FILTER4x8\_001 - MATCHED\_FILTER4x8 - beh SOF\_TRACK8\_001 - SOF\_TRACK8 - BEHAVIOR (src\BER2 Inst\_PC\_16 - PC\_16 - BEHAVIOR (src\BER2\PC\_16.vhd) SOF\_TRACK8\_001 - SOF\_TRACK8 - BEHAVIOR (src\BER2\sof\_track8.vhd)

AWGN.vhd generates a precise Additive White Gaussian Noise. The noise bandwidth is 2\*symbol rate.

INFILE2SIM.vhd reads an input file. This component is used by the testbench to read a modulated samples file generated by the siggen fsk1.m Matlab program for various Eb/No and frequency offset cases.

SIM2OUTFILE.vhd writes three 12-bit data variables to a tab delimited file which can be subsequently read by Matlab (load command) for plotting or analysis.

# VHDL simulation

VHDL testbenches are located in the /sim directory.

The tbcom1827 modemonly.vhd connects the modulator and demodulator back to back. Endto-end BER tests can be performed as the com1827 tx.vhd transmitter includes a built-in pseudo-random sequence generator and the

com1827\_rx.vhd receiver includes a built-in Bit Error Rate Tester.

The tbcom1827\_demodonly.vhd testbench reads a tab-delimited stimulus files of modulated I/Q baseband complex input samples.

# Matlab simulation

Matlab programs are located in the /matlab directory.

The siggen\_fsk1.m program generates a stimulus file input.txt for use as input to either the demodulator VHDL simulation (tbcom1827\_demodonly.vhd) or the demod\_soqpsktg.m Matlab program. The stimulus file includes a continuous stream of pseudo-random (PRBS11) data bits, convolutional code encoding, SOQPSK modulation, additive white Gaussian noise, channel filtering, frequency translation and quantization.

Care must be taken to match the modulator configuration in siggen\_fskl.m and the demodulator configuration in tbcom1827\_demodonly.vhd.

This setup allows end-to-end BER testing, as the demodulator com1827\_rx.vhd includes a built-in bit error rate tester.

The demod\_soqpsktg.m program applies key demodulation techniques to the stimulus file input.txt and computes the BER. It does not include AFC, AGC nor carrier and symbol timing tracking loops.

# Specifications

[1] IRIG-106 "Telemetry Standard RCC Document 106-07, Chapter 2", for SOQPSK TG

[2] MIL-STD-188-181B for SOQPSK-MIL

### **Reference documents**

[3] "Comparison of Noncoherent detectors for SOQPSK and GMSK in Phase Noise Channels", Afzal Syed, MS thesis, University of Kansas, 2007

[4] "A Hardware Implementation of a Coherent SOQPSK-TG Demodulator for FEC Applications", Gino Pedro Enrique Rea Zanabria, MS thesis, University of Kansas, 2011

# **ComBlock Ordering Information**

COM-1827SOFT\_SOQPSK modem, VHDL source code / IP core

ECCN: EAR99

# **Contact Information**

MSS • 845-N Quince Orchard Boulevard • Gaithersburg, Maryland 20878-1676 • U.S.A. Telephone: (240) 631-1111 E-mail: info@comblock.com