## Summary - IQ Imbalance Fixer

| Name              | $\mathrm{iq\_imbalance\_fixer}$                                    |
|-------------------|--------------------------------------------------------------------|
| Worker Type       | Application                                                        |
| Version           | v1.4                                                               |
| Release Date      | September 2018                                                     |
| Component Library | ocpi.assets.dsp_comps                                              |
| Workers           | iq_imbalance_fixer.hdl                                             |
| Tested Platforms  | xsim, isim, modelsim, alst4, ml605, ZedBoard(PL), Matchstiq-Z1(PL) |

### **Functionality**

The IQ Imbalance Fixer compensates for amplitude and phase differences between quadrature I and Q input rails caused by differences in quadrature A/D devices. The goal is to drive the corrected output power difference between rails to zero and to also drive the corrected phase difference between rails to zero. This is accomplished via a feedback loop where the power and phase differences are measured and applied to the Q rail. In other words, the I output is a delayed version of the I input while the Q output has been corrected by removing amplitude and phase errors. This results in removal of the input spectral image.

The power difference is measured by  $I^2 - Q^2$ , while the phase difference is measured by I\*Q. These loop errors are averaged over  $2^{+log2\_averaging\_length} - 1$  input samples, which defines the update interval. The loop errors are filtered by single-pole IIR filters at the end of the update interval. The filters have a pole on the unit circle and have gain of  $2^{-neg\_log2\_loop\_gain}$ . The filter outputs become the current  $c\_corr$  and  $d\_corr$  error correction values that are applied to the I and Q input streams, respectively. Input values are presented as corrected output values following four data valid cycles. This circuit operates at the full clock rate - that is, data valid may be held asserted every clock cycle.



Figure 1: Block Diagram of VHDL, highlighting inferred Xilinx DSP48E1 primitives

#### Worker Implementation Details

#### iq\_imbalance\_fixer.hdl

The IQ Imbalance Fixer worker inputs complex signed samples and removes the spectral image caused by a quadrature gain imbalance between I and Q rails and also by a phase imbalance (not a perfect 90 degrees between sine and cosine) between the complex rails. The averaging time and the error loop gain of the worker are programmable, as is the ability to bypass the worker and to update/hold the calculated error correction values. For the HDL worker, a generic controls inclusion of a peak detection circuit applied to the worker's output samples.

An ENABLE input is available to either enable (true) or bypass (false) the circuit. Note that bypass registers are not used. Instead, feedback error values are held constant at values that do not alter the Q rail. The UPDATE input, by default true, may be disabled to hold the loop errors to a constant value. Note that the ENABLE input takes priority over the UPDATE input.

This implementation uses seven Xilinx DSP48e multipliers to process input data at the clock rate - i.e. this worker can handle a new input value every clock cycle. A peak detection circuit may be optionally included at build-time, which provides monitoring of the output amplitude, and may be used to influence the input gain. This worker will produce valid output four clock cycles after each valid input.

The IQ Imbalance Fixer worker utilizes the OCPI *iqstream\_protocol* for both input and output ports. The *iqstream\_protocol* defines an interface of 16-bit complex signed samples. The DATA\_WIDTH\_p parameter may be used to reduce the worker's internal data width to less than 16-bits.

#### Theory

A mathematical representation of a quadrature signal is given by the formula  $cos(2\pi t/T) + jsin(2\pi t/T)$ . If we let  $\omega = 2\pi t/T$ , the equation of an imbalanced quadrature signal is  $cos(\omega) + j\alpha sin(\omega + \beta)$ , where  $\alpha$  is the amplitude difference and  $\beta$  is the phase difference between I/Q rails. If we take the imbalanced signal and mix it with another frequency, such as upconverting or downconverting the signal, we essentially multiply the input signal by the tone  $cos(\omega 0) + jsin(\omega 0)$ . The output signal then becomes a frequency-shifted version of the input signal given by  $cos(\omega - \omega 0) + j\alpha sin(\omega - \omega 0 + \beta)$ . The result is a spectral image of the original signal at  $-(\omega - \omega 0)$ . In the case of a non-zero linear combination of sine and cosine waves (which we have from a quadrature A/D, where the Q rail is simply a phase shift of  $\pi/2$  of the I rail), we may use the trigonometric identity  $\alpha sin(x + \beta) = Ccos(x) + Dsin(x)$ , where C and D are constants and are the phase and amplitude errors applied to the I and Q input values, respectively. Thus the corrected output rails become I and CI + DQ.

## **Block Diagrams**

#### Top level

enable, update, log2\_averaging\_length
neg\_log2\_loop\_gain, peak, messageSize



#### State Machine

Only one finite-state machine (FSM) is implemented by this worker. The FSM supports Zero-Length Messages.



Figure 2: Zero-Length Message FSM

Note: In future releases this finite-state machine will be replaced with a register-delay based mechanism, currently exemplified in the dc offset filter

## Source Dependencies

### $iq\_imbalance\_fixer.hdl$

- $\bullet \ projects/assets/components/dsp\_comps/iq\_imbalance\_fixer/iq\_imbalance\_fixer.vhd \\$
- $\bullet \ projects/assets/hdl/primitives/dsp\_prims/dsp\_prims\_pkg.vhd \\ projects/assets/hdl/primitives/dsp\_prims/iq\_imbalance/src/iq\_imbalance\_corrector.vhd \\$
- $\bullet \ projects/assets/hdl/primitives/util\_prims/util\_prims\_pkg.vhd \\ projects/assets/hdl/primitives/util\_prims/pd/src/peakDetect.vhd$

# ANGRYVIPER Team

# Component Spec Properties

| Name                  | Type   | SequenceLength | ArrayDimensions | Accessibility      | Valid Range | Default | Usage                                                     |  |
|-----------------------|--------|----------------|-----------------|--------------------|-------------|---------|-----------------------------------------------------------|--|
| enable                | Bool   | -              | -               | Writable, Readable | Standard    | true    | Enable/bypass control                                     |  |
| update                | Bool   | -              | -               | Writable, Readable | Standard    | true    | Update the calculated amplitude and phase errors, or hold |  |
|                       |        |                |                 |                    |             |         | a previously calculated value                             |  |
| log2_averaging_length | UChar  | -              | -               | Writable, Readable | 1-31        | 11      | Controls the update interval to be applied to the input,  |  |
|                       |        |                |                 |                    |             |         | where $2^n + 1$ samples define the averaging length       |  |
| neg_log2_loop_gain    | UChar  | -              | -               | Writable, Readable | 1-31        | 5       | Controls the loop gain, where the value is $2^{-n}$       |  |
| messageSize           | UShort | -              | -               | Writable, Readable | 8192        | 8192    | Number of bytes in output message                         |  |

# Worker Properties

## $iq\_imbalance\_fixer.hdl$

| Type     | Name           | Type  | SequenceLength | ArrayDimensions | Accessibility       | Valid Range | Default | Usage                                  |
|----------|----------------|-------|----------------|-----------------|---------------------|-------------|---------|----------------------------------------|
| Property | DATA_WIDTH_p   | ULong | -              | -               | Readable, Parameter | 1-16        | 16      | Worker internal non-sign-extended data |
|          |                |       |                |                 |                     |             |         | width                                  |
| Property | ACC_PREC_p     | ULong | -              | -               | Readable, Parameter | 3-?         | 34      | Accumulator bit width                  |
| Property | PEAK_MONITOR_p | Bool  | -              | -               | Readable, Parameter | Standard    | true    | Include a peak detection circuit       |
| Property | peak           | Short | -              | -               | Volatile            | Standard    | 0       | Read-only amplitude which may be use-  |
|          |                |       |                |                 |                     |             |         | ful for gain control                   |

# Component Ports

| Name | Producer | Protocol          | Optional | Advanced | Usage                  |
|------|----------|-------------------|----------|----------|------------------------|
| in   | false    | iqstream_protocol | false    | -        | Signed complex samples |
| out  | true     | iqstream_protocol | false    | -        | Signed complex samples |

# Worker Interfaces

## $iq\_imbalance\_fixer.hdl$

| Type            | Name | DataWidth | Advanced                | Usage                  |  |  |  |
|-----------------|------|-----------|-------------------------|------------------------|--|--|--|
| StreamInterface | in   | 32        | ZeroLengthMessages=true | Signed complex samples |  |  |  |
| StreamInterface | out  | 32        | ZeroLengthMessages=true | Signed complex samples |  |  |  |

# Control Timing and Signals

The IQ Imbalance Fixer worker uses the clock from the Control Plane and standard Control Plane signals.

## Worker Configuration Parameters

 $iq\_imbalance\_fixer.hdl$ 

Table 1: Table of Worker Configurations for worker: iq\_imbalance\_fixer



## Performance and Resource Utilization

 $iq\_imbalance\_fixer.hdl$ 

Table 2: Resource Utilization Table for worker: iq\_imbalance\_fixer

| Configuration | OCPI Target | Tool    | Version | Device           | Registers (Typ) | LUTs (Typ) | Fmax (MHz) (Typ) | Memory/Special Functions |
|---------------|-------------|---------|---------|------------------|-----------------|------------|------------------|--------------------------|
| 0             | zynq        | Vivado  | 2017.1  | xc7z020clg484-1  | 720             | 1089       | N/A              | DSP48E1: 7               |
| 0             | virtex6     | ISE     | 14.7    | 6vlx240tff1156-1 | 720             | 1475       | 163.827          | DSP48E1: 7               |
| 0             | stratix4    | Quartus | 17.1.0  | EP4SGX230KF40C2  | 947             | 1150       | N/A              | DSP18: 14                |

#### Test and Verification

A single test case is implemented to validate the IQ Imbalance Fixer component. An input file is generated consisting of a waveform with tones at 5 Hz, 13 Hz, and 27 Hz, and creates a spectral image by both adding different gain to I and Q rails and also adding an additional 10 degrees of phase to the sine portion of the complex signal. The result is the addition of spectral image tones at -5 Hz, -13 Hz, and -27 Hz. The complex waveform is then scaled to fixed-point signed 16-bit integers, with a maximum amplitude of 31000 to avoid roll-over.

Time and frequency domain plots may be viewed in Figures 3 and 4 below, respectively, where the time domain plot represents the first 128 complex samples in the file.





Figure 3: Time Domain Tones with Spectral Image

Figure 4: Frequency Domain Tones with Spectral Image

Verification of output data is performed only on the second half of the output, which represents the steady state of the component. The output is first checked that the data is not all zero, and is then checked for the expected length of 65,536 complex samples. Once these quick checks are made both the input and output data are translated to the frequency domain, where a FFT is performed, and then power measurements are taken at 5 Hz, 13 Hz, 27 Hz, -5 Hz, -13 Hz, and -27 Hz. The input and output power measurements are compared to validate that the IQ spectral image has been attenuated and that the other tones have not been attenuated. In addition, the FFT bin with the maximum power in the range of DC to +Fs/2 is compared to the maximum power bin in the range of -Fs/2 to DC to verify at least 65 dB of suppression has taken place with respect to the spectral image. Figures 5 and 6 depict the filtered results of the three tone input, where the time domain plot represents the first 128 complex samples in the file.





Figure 5: Time Domain Tones with Spectral Image removed

Figure 6: Frequency Domain Tones with Spectral Image removed