Hardware Design for Quadrature Phase Detection Algorithm in ECVT

Imamul Muttakin, Arbai Yusuf, Rohmadi, Wahyu Widada, Warsito P. Taruno
CTECH Labs Edwar Technology Co.
Tangerang, Indonesia
Email: {imuttakin, arbai, rohmadi, wwidada, wsito}@c-techlabs.com

Abstract—Core processing for calculating phase and amplitude of the detected signal was built on FPGA (Field-Programmable Gate-Array) platform. Phase shift demodulation algorithm employs IP core provided by Xilinx FPGA. Direct digital synthesizer (DDS), multiplier, accumulator, and CORDIC (coordinate rotation digital computer) modules were used as excitation-reference signal generator, signal multiplication, accumulation, and conversion to polar coordinate in order to conduct trigonometric operation respectively. Hardware design was emulated on MATLAB-Xilinx System Generator to observe its performance. Phase detection range 0-114.58° and mean absolute error 0.58° have been achieved. Data processing rate solely at digital signal stage was approximately 100data/s suitable for 32-channel ECVT (electrical capacitance volume tomography) system.

Keywords—quadrature demodulation; phase detection; system generator; FPGA; ECVT

I. INTRODUCTION

Phase detection is one of the most important feature in data acquisition system for electrical capacitance volume tomography (ECVT). ECVT is a volumetric (real-time 3D) tomography technique based on capacitance measurement which has replaced classical system in two-dimensional slicing for tomography imaging [1]. Data acquisition system collects data obtained from sensor to be formed and sent to computer which manipulates the data pattern into image using specific algorithm.

In the well-known circuitry for capacitance to voltage (C-V) conversion, measurement accuracy is affected by phase conformity between output C-V signal and reference signal. This circumstance makes phase tracking necessary for system’s reliability to reduce phase error [2][3]. Fig. 1 shows a phase sensitive demodulation (PSD) mechanism in front of C-V circuit to extract information from measured capacitance.

According to Fig. 1, if both $V_{ref}$ and $V_2$ signals have identical phase, $V_o$ will only related to amplitude of input signals. However, practically two signals added into demodulator will generate additional phase difference which decreases output amplitude and causes measurement error. The additional phase difference is relevant toward stray capacitance, and different stray capacitance brings different phase angle. Therefore, phase shift will impose certain error. By using coherent demodulation to detect the signal with phase tracer circuit, this kind of problem can be well addressed. Consequently, multiplier output will reach maximum, circuit is stray-immune, in the same time sensitivity and stability of the system can be improved [2].

Performance improvement will be achieved by implementing most functionality into digital hardware rather than analog. FPGA is employed as control processing core, excitation signal generation, and signal demodulation. The modular design of FPGA produces minimal hardware overhead, flexible, fast, and stable in order to facilitate further development of measurement system.

II. QUADRATURE DEMODULATION

In phase detection, sine signal needs to be demodulated with measured parameter. Digital demodulation makes use of reference signal generated from DDS to digitally modulate measured signal to obtain its amplitude and phase.

\[
R = \sum_{n=0}^{N-1} i(n) \cdot u(n) = A \sin \left( \frac{2\pi n}{N} + \theta \right) \cdot A \sin \left( \frac{2\pi n}{N} \right) = NA \cos \theta
\]

\[
l = \sum_{n=0}^{N-1} q(n) \cdot u(n) = A \cos \left( \frac{2\pi n}{N} + \theta \right) \cdot A \sin \left( \frac{2\pi n}{N} + \theta \right) = NA \sin \theta
\]

\[
Z = \sqrt{R^2 + l^2}; \theta = \tan^{-1} \frac{l}{R}
\]

This synchronous modulation and demodulation (PSD also known as phase shift demodulation) has high precision and adaptation level based on matched filter theory which is liner time-invariant by maximizing signal-to-noise ratio (SNR). Considerations in PSD are: input signal frequency and phase must be similar, reference signal should be justified accurately, anticipate phase shift because of stray capacitance and resistance channel, and degradation of SNR due to
frequency difference between driving signal and reference signal.

Demodulation is accomplished through several steps. First, phase difference between digitized reference signal and measured signal is identified. Second, delay the reference signal with specific number from sampling period according to phase difference value obtained from preceding step to match reference signal’s phase with measured signal’s phase. Last, multiply the measured signal with adjusted reference signal in one sine wave period and then accumulate the results accordingly [4].

Integration of DDS and PSD module into single FPGA hardware improves systematic SNR and simplifies peripheral circuits. For real-time processing, large amount of data on front-end with high-speed and relatively simple pre-processing architecture are suitable for FPGA implementation [5].

III. HARDWARE DESIGN METHOD

Phase detection algorithm i.e. phase shift demodulation is built using Xilinx FPGA IP core. DDS, multiplier, accumulator, and CORDIC are functioned as excitation-reference signal generation, signal multiplication, accumulation, and conversion to polar coordinate in order to conduct trigonometric operation respectively.

Fig. 2. Quadrature phase detection scheme

Block diagram in Fig. 2 represents signal flow (contains phase shift) with quadrature demodulation mechanism, where accumulation results will be brought to inverse tangent calculation to obtain phase output value. Equation identity of multiplication between sine with sine and cosine also division sine-cosine is elaborated in (2).

\[
\begin{align*}
A \sin(\omega_1 t + \theta) \times \sin(\omega_2 t) &= \frac{A}{2} \cos((\omega_1 - \omega_2)t + \theta) - \frac{A}{2} \cos((\omega_1 + \omega_2)t + \theta) \\
A \sin(\omega_1 t + \theta) \times \cos(\omega_2 t) &= \frac{A}{2} \sin((\omega_1 - \omega_2)t + \theta) + \frac{A}{2} \sin((\omega_1 + \omega_2)t + \theta) \\
\tan \theta &= \frac{\sin \theta}{\cos \theta}
\end{align*}
\]

Therefore, phase can be extracted if the detected signal is multiplied with reference sine and cosine signal, both of which have identical frequency. Sum frequency component is then eliminated by accumulating multiplication result. As been known, accumulation of symmetrical signal with zero offset will produce zero mean value so that the sum frequency component signal will vanish from equation. In the end, with division operation tangent phase angle will be obtained and then the inverse is phase value. Those division and inverse mechanism are conducted after conversion into polar domain using CORDIC operation.

Implementation of the mechanism on Xilinx System Generator is described in Fig. 3

Whereas, signal flow is depicted in Fig. 4 below.

Synchronous sine and cosine signal produced by DDS IP core implemented in FPGA are directly used in digital domain for demodulation. Compared with conventional analog demodulation, the method can eliminate the possibility of frequency mismatch and phase variation between signals. Computation process is conducted in dedicated modules (multiplier-accumulator) and avoiding data buffer so that digital demodulation can be performed online in order to maximize acquisition rate. Consequently, it will introduce a relatively simple system with better reliability [6].

IV. SIMULATION RESULT

Hardware-software co-simulation using MATLAB-Xilinx System Generator allows to design and observe the characteristics of hardware; on the other hand manipulate the input signal and process the output signal by software. Fixed-point number will be used to maintain consistency with practical running process in digital device [7].
A. MATLAB-Xilinx System Generator

The development issues in hardware design using MATLAB Xilinx System Generator comprises: 1) determining design specification, 2) designing a system in Simulink utilizing System Generator blocks, 3) simulating the design, 4) generating hardware description language (HDL) code, 5) implementing HDL code into target hardware [8]. Step 1 through 3 were applied to foresee system’s performance and capability for further ECVT development.

Implementation result of Xilinx IP Core multiplier and accumulator for quadrature demodulation calculation is shown in Fig. 5. In the system, input sine signal 50kHz (chosen operation frequency) is applied with phase shift 1 radian. Hardware multiplier then multiply the signal with each of reference sine and cosine signal where the frequency is set similar to the input signal. Each multiplication result is brought into hardware accumulator to be accumulated thus high frequency component will be eliminated and accumulation of phase function will remain. Trigonometric operation \( \text{atan2} \) (two-input inverse tangent) is applied using MATLAB function. On the display, phase value (in radian) is shown.

B. System Overview

Overview of the system for phase shift demodulation implemented on Xilinx System Generator is shown as following Fig. 6.

<table>
<thead>
<tr>
<th>TABLE I. SYSTEM SPECIFICATION</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Operational Frequency</strong></td>
</tr>
<tr>
<td>Phase Detection Range</td>
</tr>
<tr>
<td>Data</td>
</tr>
<tr>
<td>Rate</td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
<tr>
<td></td>
</tr>
</tbody>
</table>

From the design, system specification that can be provided is formulated in TABLE I.
Equation (3) and (4) were used to derive data rate and mean absolute error (MAE) respectively,

$$\text{Throughput} = \frac{f_{clk} \cdot f_{ADC}}{f_{op} \cdot N_{\text{period}} \cdot \frac{n(n-1)}{2}}$$

$$(3)$$

$$\text{MAE} = \frac{1}{N} \sum_{i=1}^{N} |f_i - c_i|$$

$$(4)$$

where $f_{clk}$ = hardware clock; $f_{ADC}$ = ADC sampling rate; $f_{op}$ = operational frequency; $N_{\text{period}}$ = number of signal period; $n$ = measurement channel; $N$ = number of data; $f_i$ = theoretical value; $c_i$ = measured value.

Fig. 7. Measurement error plot

Measurement error is plotted in Fig. 7 showing the most linear result at 16-bit data and 100MHz clock frequency.

V. CONCLUSION

Core processing for calculating phase and amplitude of the detected signal was designed on FPGA platform. Hardware-software co-simulation using MATLAB-Xilinx System Generator allows to design and observe the characteristics of hardware; on the other hand manipulate the input signal and process the output signal by software. To perform hardware test with real input and output, the design needs to be downloaded onto FPGA and connected with external blocks.

The optimum system design, adjusted to 16-bit data resolution and clock speed 100MHz, gives phase detection range 0-114.58° (or ±57.29°) and mean absolute error 0.58°.

Data processing rate solely at digital signal stage is approximately 1785data/s (for 8-channel), 416data/s (for 16-channel), and 100data/s (for 32-channel).

ACKNOWLEDGMENT

Author would like to thank researchers of CTECH Laboratories, Edwar Technology Co. (www.e-techlabs.com) who have helped in experiment.

REFERENCES


