# Load cell resonance frequency analyser

Frequency analysis system for load cell based conveyor belt weighing systems

Bachelor Graduation Thesis – TUDelft Electrical Engineering 19 June 2020

Jonathan Dijkstra (4696778) & Mauries van Heteren (4712145)





**Challenge the future** 

# Abstract

<span id="page-1-0"></span>In this thesis, the design of a frequency analysis system for conveyor belt weighing systems is designed. The objective of the thesis is to detect a change in resonance frequency, caused by a change of pressure applied to a sensor. The design features a resolution of 10 000 discrete frequency levels in a bandwidth of 0.5 MHz. Noise division of a pseudo random noise (PRN) signal is used to obtain a clear frequency spectrum. An ADC is implemented to digitize an analog input signal. Furthermore, a digital down converter using a CIC filter and CORDIC based controlled digital oscillator is applied. The frequency-domain translation is achieved using an FFT. Lastly, an interpolation over the spectrum is realized to increase the frequency resolution. Additionally, an analytical analysis of the primary noise sources in the system is given. The entire system is simulated in MATLAB to validate the designed blocks.

# Preface

<span id="page-2-0"></span>This bachelor thesis is written as part of the Bachelor Graduation Project, which is the final part of the bachelor program Electrical Engineering at the TU Delft. This thesis is part of a project initiated by Intralox: "*A passive wireless load cell for in-situ product weight and position sensing on modular plastic conveyor belts*"[[11](#page-55-0)]. Together with four other enthusiastic group members, we accepted the challenge.

The time span of the project was two months. We delved deep into the world of digital frequency analysis systems. The project was a great opportunity for us to learn new things and to develop skills in structured problem solving. We could apply the knowledge obtained in the bachelor, as well as get more in-depth insight into the used theory.

We could not have done this project without the help of our supervisor dr. ir. Chris Verhoeven. We would like to express our gratitude to Chris for his valuable guidance and advice during the project. Furthermore, we are very grateful for the assistance Intralox provided us with. We would like to thank Sven-Erik Haitjema and Lazlo Kleczewski in particular. They provided us with important and relevant knowledge about the system and delivered us tools and guidance for the project.

Also, we would like to thank dr. Jaap Hoekstra for being in the jury during our green-light assessment. He gave us with useful feedback about our designed system.

Finally, we like to thank our fantastic colleagues Rik Bokhorst, Ruben van den Bos, Jasper Insinger and Rogier Fischer for helping us with their skills and knowledge. Our productive collaboration and their assistance were of great importance for the final result of the project.

> *Jonathan Dijkstra & Mauries van Heteren Delft, June 2020*

# **Contents**



# Introduction

1

### <span id="page-4-0"></span>**Problem definition**

Product weighing for conveyor belt systems is a technology with applications in the aviation, automotive, logistics and food industry. With increasing industrialisation and automation of the industries, the demand for high throughput, accurate weighing system has emerged. Conventional weighing systems require weighing scales which require extra spacing in between products on the belt, lowering the throughput of the conveyor system. A system using the conveyor belt to determine the weight of a product on the belt (see Figure [1.1](#page-4-1)) has advantages over conventional weighing systems. It does not require extra spacing between products since the belt itself is used to determine the packet weight. Furthermore, packets can be weighted side by side on the belt, enabling higher product throughput of the conveyor belt system. The benefits of in-situ weighing extend to the possibility of acquiring feedback of the relative position of the product on the conveyor belt. Furthermore, it provides the possibility to determine physical properties other than weight such as the centre of gravity and orientation of the product.

<span id="page-4-1"></span>

Figure 1.1: An overview of the weighing system.

Such a weighing system would consist of a load cell placed in the belt, and a receiver system placed beneath the belt. The load cell and receiver system are guidelines provided by Intralox for suitable implementation of the weighing system into the normal Intralox conveyor belt standards. This system has been decomposed into three parts (see Figure [1.2](#page-5-0)). Each part corresponds to a subgroup for the project. Their tasks can be described as:

- **Sensor group:** Has the task to design a load cell which translates mechanical deformation into a change in electrical properties of a sensor circuit [\[2\]](#page-55-2).
- **Reader group:** Has the task to design a reader circuit which reads the change in electrical properties of the sensor circuit and translates this change into a signal [\[7\]](#page-55-3).

<span id="page-5-0"></span>• **Analysis group:** Has the task to interpret the signal and detect mechanical deformation of the load cells. This thesis focuses on the development of the analyser subsystem.



Figure 1.2: An overview of the project scope

### **Goal of the analyser**

The project objective of the analyser is to design a signal processing system that uses the output signal of the reader group in order to detect the resonance frequency of the sensor and translate that to 1 of 10 000 levels of deformation of the sensor.

# **State-of-art-analysis**

The analysis of signals in frequency domain is a mature field. Many techniques to manipulate signals can be identified and explored. These techniques are discussed in this section.

The first technique is the analog to digital conversion. When a signal is digitized, it is usually easier to manipulate. There are lots of different architectures of ADCs. From the literature, it was found that four basic architectures are used most in practice[[13\]](#page-55-4). The first is successive approximation ADC, which is used in data acquisition systems and industrial applications. The next type is the sigma-delta architecture, which is used in applications where a resolution from 12 to around 24 bits is needed. They are used, for example, in signal conditioning applications [\[9\]](#page-55-5). Pipeline ADCs are used in many types of instrumentation, including spectrum analyzers, and medical imaging. Finally, flash ADC architecture is used for very high-frequency applications.

Another technique is the conversion of a signal to frequency-domain using a Fourier transform. This is used to analyze the frequency spectrum of a signal. An example of this is a spectrum analyzer.

In order to perform frequency analysis, a fast Fourier transform can be used for translation to frequency domain. When a greater frequency resolution is desired, spectrum interpolation can be applied. In this method, different bin frequency amplitudes are interpolated in the range of the desired frequency. Parabolic and Gaussian interpolation can be used[[6\]](#page-55-6). Another technique is windowing. Using windowing the discontinuities at the edges of the time window are ignored, resulting in lower side lopes in the Fourier Transform of the sensed data[[3](#page-55-7)].

Filters are used frequently in digital signal processing. A decimation filter, for instance, can be used to lower the sampling frequency of a signal for more efficient processing.

Some of these techniques are applied in a Software Defined Radio (SDR). This is a radiocommunication system that uses hardware for the implementation of its components. The real-world application of SDR is only possible since the fast-developing possibilities of digital electronics[[1](#page-55-8)]. The digital processing techniques that are usually used in SDR are, for example, an ADC, decimation filter and FIR filters.

Furthermore, spectrum analysers are existing technologies for providing insight in the frequency content of a signal. Their the resolution of such an analyser depends on the speed of the analyser. Swept tune spectrum analysers use superheterodyne receivers and band pass filters. The centre frequency of the receiver is swept to obtain a frequency spectrum. FFT based spectrum analysers sample the input and perform a FFT over the input. The centre frequency is reduced to reduce the sampling frequency of the FFT.

Frequency counters are another class of instruments used for measuring the frequency of a signal. It counts the number of oscillations in the period of time. Accurate time bases are required to keep track of the gate time of the frequency counter. In general, frequency counters can be very precise, but not suitable for industrial applications.

# **Thesis synopsis**

The outline of this thesis is structured in the following fashion. In Chapter [2,](#page-7-0) the design requirements of the analyser are stated. Next, Chapter [3](#page-9-0) describes the outline of the system. It introduces the system components and the main design parameters. Chapter [4](#page-14-0) and [5](#page-22-0) elaborate on the proposed design as a solution for the identified problem. In Chapter [6](#page-26-0) the implementation and validation results are shown. The thesis ends with a discussion of the results and a conclusion.

 $\bigg)$ 

# Programme of requirements

### <span id="page-7-1"></span><span id="page-7-0"></span>**2.1. Requirements for the analyser group**

The main goal of the analyser subsystem is to design a system that is able to read out the peak frequency of an input signal. In order to come to a verifiable design, some requirements must be set. Different categories of requirements can be identified. All requirements for the entire project are listed in in Appendix [C.](#page-38-0)

#### **Analyser requirements**

The mandatory requirements describe what the analyser chain shall do to obtain the goal of the system. They describe the very core of the subsystem. Some trade-off requirements are given as well.

<span id="page-7-5"></span><span id="page-7-3"></span><span id="page-7-2"></span>

Table 2.1: Requirements for the design of the analyser.

#### <span id="page-7-6"></span><span id="page-7-4"></span>**Analyser-Reader interface requirements**

The interface requirements are stated below:

Table 2.2: Requirements for the interface between the analyser and the reader







# 3 System outline

### <span id="page-9-1"></span><span id="page-9-0"></span>**3.1. Detection method**

As described in Chapter [1](#page-4-0), the system consists of three subsystems; the sensor, the reader and the analyser. The sensor and reader groups have made design choices which can be read in the reports about those subsystems. The team has decided to design a system consisting of a resonant sensor that is inductively coupled to a readout circuit. Pseudo-Random-Noise (PRN) is sent into the reader circuit and filtered by the sensor impedance. In this way, frequencies that do not resonate with the sensor circuit are attenuated. The filtered signal is sent to the analyser to determine the resonant frequency, which is related to the force on the sensor.



Figure 3.1: An overview of the entire weighing system

#### **Interface with reader circuit**

The interface between the analyser and the reader consists of the exchange of two signals:

- 1. PRN is sent to the reader as an input of the reader circuit.
- 2. Filtered PRN is received from the reader as an input of the analyser.

The sensor will be designed to resonate between 26.9 MHz and 27.4 MHz  $<sup>1</sup>$  $<sup>1</sup>$  $<sup>1</sup>$  The filtered PRN will,</sup> therefore, be limited to frequencies within this bandwidth.

In the analyser, the frequency-domain representation of the filtered PRN is divided by the frequencydomain representation PRN sent to the reader to obtain the filter characteristic of the sensor. Noise components within the analyser such as the quantization of a signal and filter components can be modelled as noise sources.

#### **Digital signal processing**

The signal will be analysed digitally. A design using digital signal processing techniques is easy to implement on a processor or an FPGA. Digital implementation also allows for quick adaptation of the design, which is specifically useful when prototyping. Furthermore, the precision of digital signal processing techniques is comparable to that of analog signal processing techniques. Since it is prohibited to compose a real-life prototype for the project, using digital techniques raises opportunities for simulating and prototyping with the help of MATLAB and VHDL.

<span id="page-9-2"></span><sup>1</sup>Dutch government provides constraints in frequency usage in the Netherlands. Between 26.9 MHz and 27.4 MHz is a frequency band for amateur radio usage in the Netherlands [\[5\]](#page-55-9).

### <span id="page-10-0"></span>**3.2. Components**

Since now the main challenge for the system has been identified, and the choice of using digital signal processing techniques has been made, the necessary components for the system can be classified. In order to do this, the requirements and functional analysis of the analyser are used.

#### **Analog to digital conversion**

The first obvious step in the chain is the analog to digital conversion. The signal is sampled and quantized in this step. The reason behind the use of an ADC lies in the design choice of digital signal processing.

#### **Digital down conversion**

As stated before, the used frequency range for the system is between 26.9 MHz and 27.4 MHz. This means the frequency range from 0 Hz to 26.9 MHz does not contain interesting frequencies for the system. Down conversion in the frequency domain reduces the data rate which results in faster processing. Doing this, no signal information will be lost, but the computational costs in hardware will be reduced. Furthermore, it will result in a much higher frequency resolution of the Fourier Transform, as can be seen from Equation [3.1](#page-10-1) discussed in the next block. The fourier transform is only computed over the frequencies containing information. The DDC has two main functionalities. First of all, it places the frequency band of interest, 26.9 MHz to 27.4 MHz, to baseband (0 to 0.5 MHz). Secondly, it reduces the sampling rate of the input with a decimation factor  $R$ .

#### **Frequency analysis**

As stated in Requirement [FR-MR01,](#page-7-2) the analyser shall be able to detect 10 000 frequency levels of the input signal. In order to do this, the input signal first needs to be translated to frequency-domain. A commonly used method is frequency counting. However, this method requires stability in frequency over the gate time to be accurate. Given the short measurement time and frequency content changing due to changes in the coupling of the sensor and the reader circuit, the frequency counter is not a viable design option.

Another method for analysing the frequency content is using spectral analysis. This can be done using a Fourier Transform, more specifically an FFT, which allows fast computation. Using the FFT, a peak in the frequency spectrum can be used to detect the resonance frequency of the signal.

#### **Frequency resolution**

In order to determine 10 000 levels of deformation, 10 000 levels of resonance frequency from the impedance response of the reader circuit have to be detected. Given the bandwidth of the input signal, the required frequency resolution  $R_{required}$  is:

<span id="page-10-1"></span>
$$
R_{required} = \frac{B}{n} = \frac{0.5MHz}{10000} = 50Hz
$$
\n(3.1)

As can be seen from the requirements for the overall system, the belt will move with a speed of 2 m/s. Furthermore, the sensor will have a length of 2 cm. This means the maximum time of data accumulation is 10 ms. Given this measurement time, the maximum obtainable resolution  $R_{measurement}$  is (See Appendix [B.1](#page-35-1) for the derivation of this formula).

<span id="page-10-2"></span>
$$
R_{measurement} = \frac{1}{t_{measurement}} = \frac{1}{10ms} = 100Hz
$$
\n(3.2)

The resonance frequency peak can be located between the FFT bins. Therefore, it is required to perform an additional operation over the spectrum to obtain a higher resolution in resonance frequency.

#### **Methods for increasing the frequency resolution**

The frequency resolution can be increased by performing a weighted average over the FFT bins, or by interpolating in between the FFT bins. The first method is most appropriate if a few bins are available. However, the frequency response of the reader and sensor circuit will have a smooth curve rather than a sharp spike at a single frequency[[7](#page-55-3)]. Therefore, polynomial interpolation in between FFT bins is a more appropriate method for increasing the frequency resolution.

#### **Block diagram**

Now that each block of the system is identified and elucidated, the total block diagram can be constructed. Each block represents a necessary step in the analysing chain. The block diagram of the analyser can be seen in Figure [3.2](#page-11-2).

<span id="page-11-2"></span>

Figure 3.2: The top level block diagram of the Analyser

#### **Interfaces within the block diagram**

The input of the ADC block is also the input of the analyser as a whole. This interface is the same as between the reader and analyser, as discussed before and specified in the requirements. The signal between the ADC and DDC will be a sampled signal. The frequency peak is in the range of 26.9 and 27.4 MHz. After the DDC, the signal will have a sampling frequency of 1 MHz, and the frequency peak is in the range of 0 to 0.5 MHz. After the FFT, the frequency domain representation of the signal will be fed into the interpolation block. This block outputs the final detected frequency.

### <span id="page-11-0"></span>**3.3. Noise division working principle**

As explained before, the analyser subsystem utilises a division of Pseudo-Random-Noise to obtain a frequency spectrum with a peak on the resonance frequency. The filtered PRN is divided by the nonfiltered PRN in frequency-domain, resulting in a smooth spectrum. This division will take place after the FFT block in the block diagram. More details about the noise signal can be read in the readout circuit report [\[7\]](#page-55-3). An example of this principle can be seen in Figure [3.3](#page-11-3). In this example, a sampling frequency of 125 MHz is used.

<span id="page-11-3"></span>

Figure 3.3: Division of the filtered PRN by the non-filtered PRN.

### <span id="page-11-1"></span>**3.4. Signal to noise ratio and resolution of the system Resolution**

Equation [3.1](#page-10-1) translates the design requirement of the weighing system to an output resolution of the analyser. With the detection method mentioned above, 10 000 levels of resonance frequency of the sensor within a frequency band of 0.5 MHz have to be measured. This results in an output resolution of 50 Hz in the discrete frequencies of the analyser (see Figure [3.4\)](#page-12-0). With a bin size of 50 Hz, frequencies that are within 25 Hz of the mean of the segment will be placed within that frequency level.

#### **Measurement errors**

Two types of measurement errors can be distinguished in the system:

- **Offset:** Long term errors in the system due to temperature, sensor deviation, and mechanical mounting of the system. In the reader, offsets in signal power may occur due to an offset in the input voltage of the operational amplifier. It will be assumed that this offset is negligible. In the analyser, analog circuitry around the ADC will contribute to the system offset.
- **Measurement variance:** Short term deviations due to quantization and filtering in the analyser. Thermal noise of analog circuitry components is a contribution to variance in measurement outcome. Quantization errors are uniformly distributed with a zero mean value.

The system offset greatly influences the system accuracy (see Figure [3.4](#page-12-0)). However, this accuracy can be improved by calibrating the sensor and the adjustment screws of the mechanical mounting. Statistical data of the sensor should be used to calibrate the system. However, it is impossible to perfectly calibrate the weighing system with zero offset. An important constraint for the system offset is given by Equation [3.3.](#page-12-1) It is stated that the sum of the static deviation from the midpoint and the variance of measurements in the frequency bin should be smaller than the measurement rounding, or half the system resolution. With a system resolution of 50 Hz, the offset should be smaller than 25 Hz.

<span id="page-12-1"></span>
$$
f_{offset} + 3\sigma \le R/2 \tag{3.3}
$$

<span id="page-12-0"></span>

Figure 3.4: An overview of factor that should be taken into account when designing the analyser

Quantization introduces variance in the system output and therefore reduces the precision of the analyser. Moreover, the analyser will contribute most dominantly to the variance in the detection outcome. Variances due to thermal noise in analog circuitry are orders of magnitude smaller than the noise introduced by quantization[[7](#page-55-3)]. These variances will not be discussed in this thesis.

#### **Quantization noise in the analyser**

With a standard deviation in the measured frequency, the detected frequencies may end up in the wrong frequency bin. Therefore, it is essential to obtain the minimal Signal to Noise Ratio (SNR) of the system needed to achieve 50 Hz resolution. Noise is added to the system by many sources. The readout circuit components, ADC circuit components and ADC quantization are examples of these sources. The equations for the noise sources will be given later in this document.

In order to find the minimum allowed SNR, a MATLAB simulation can be performed. Extra noise is added to the ideal filtered input (as in Figure [3.3\)](#page-11-3) until the requirements are not satisfied any more. When computing the standard deviation  $\sigma$  over a sample size of N frequency peaks (after division), information about the quality of the signal is obtained. Table [3.1](#page-13-0) shows simulation results for simulating standard deviations for different signal to noise ratios. With three standard deviations,  $3\sigma$ , 99,72% of the sample size will be within the deviation.

When the MATLAB simulation is used with a sampling frequency of 125 MHz and a resonance frequency of 27098245 Hz, the result can be seen in Table [3.1](#page-13-0). In this case, the sample size  $N = 15$ 

and 10 values for the SNR are used. Furthermore, for this test, it is assumed that the noise sources are mainly uniformly distributed.



<span id="page-13-0"></span>Table 3.1: Result of MATLAB simulation for different SNR of the input at a resonance frequency of 27098245 Hz.

#### **Minimum signal to noise ratio of the analyser**

What signal to noise ratio is acceptable for the analyser depends on the size of the offset in other parts of the weighing system, as shown in Equation [3.3](#page-12-1). With a resolution R, a centre frequency  $f_{mid}$  of a discrete frequency bin, and a deviation of  $3\sigma$ , and an offset frequency of  $f_{offset}$ , the critical frequencies  $f_{critical}$  are given by Equation [3.4.](#page-13-1) These frequencies have a risk of a wrong bin detection. A good design would reduce the bandwidth of the critical frequencies as much as possible.

<span id="page-13-1"></span>
$$
f_{critical} = [f_{mid} - R/2, f_{mid} - R/2 + 3\sigma + f_{offset}]; [f_{mid} + R/2 - 3\sigma - f_{offset}, f_{mid} + R/2]
$$
(3.4)

Table [3.1](#page-13-0) provides meaningful insights in what SNR to design for. The best SNR to aim for in the design process has a high marginal decrease deviation, as well a low enough value of that deviation that will allow calibration offset. Using these design principles, it is chosen to design a signal to noise ratio of 60 dB. The value of  $3\sigma$  at 60 dB is 1.062 Hz. To design for a higher ratio would give an insignificant gain in deviation, while making hardware implementation much more costly. Lower signal to noise ratios have possible higher marginal gain, but the order of magnitude of deviation is in Hz which would require extremely precise calibration.

To derive the maximum allowed noise power, first, the signal power of the input has to be known. From the reader subsystem, it is known that the implementation of the system will pass a signal to the analyser with a value of 1 Vpp. It is a normally distributed signal with a standard deviation of 0.33. This translates to a signal power of 0.33<sup>2</sup> $\frac{V^2}{V}$  $\frac{V^2}{Hz}$ . Therefore, the maximum allowed noise power is  $\frac{0.33^2}{4.0 \frac{504}{A}}$  $\frac{0.33^2}{10^{60dB}} = 0.11 \frac{\mu V^2}{Hz}.$ 

4

# <span id="page-14-0"></span>Analog to digital and digital down conversion

### <span id="page-14-1"></span>**4.1. Analog to digital conversion**

#### **Sampling**

#### **Sampling Period**

The analog to digital converter (ADC) is the first component in the analyser signal processor. The functionality of the ADC is to digitise the output signal from the reader circuit, maintaining all the information while adding as less noise as possible. A more mathematical description of the ADC can be found in Appendix [B.1.](#page-35-1)

The Nyquist criterion states that the minimum sampling rate to sampling a signal without loss of information or aliasing is twice the bandwidth of that signal:

As described in the interface, the highest frequency is 27.4 MHz. This translates to the minimum required sampling rate of:

$$
f_s = 2f_{max} = 54.8MHz
$$
\n
$$
(4.1)
$$

#### **Noise**

The analog to digital conversion will add noise to the input signal. Noise sources in an ADC are thermal and quantization noise. Thermal noise is modelled as white noise with a normal distribution. Quantization noise is modelled as uniformly distributed. For an ADC, usually, only the quantization noise is considered[[16\]](#page-55-10). The Signal to Quantization Noise Ratio (SQNR) of an ADC can be defined as in Equation [4.2](#page-14-2) [\[16](#page-55-10)]. This equation yields the ratio between the RMS value of the full-scale input  $V_{FS}$  and the RMS value of the noise.

<span id="page-14-2"></span>
$$
SQNR_{ADC} = 20 \log_{10}(\frac{\frac{V_{FS}}{2\sqrt{2}}}{V_{noise_{RMS}}} )
$$
\n(4.2)

The SQNR in decibels is expressed as [\[10\]](#page-55-11):

<span id="page-14-5"></span>
$$
SQNR_{db} = 20 \log_{10} \left( \frac{2(N-1) \cdot q/\sqrt{2}}{q/\sqrt{12}} \right) = 6.02N + 1.76dB \tag{4.3}
$$

Where N is the number of bits in the ADC output and q the size of a quantization step. From Equation [4.2](#page-14-2) it can easily be derived that the RMS value of the noise can be written as in Equation [4.4](#page-14-3).

<span id="page-14-3"></span>
$$
V_{noise_{RMS}} = \frac{\frac{V_{FS}}{2\sqrt{2}}}{10^{\frac{SNR_{ADC}}{20}}} \tag{4.4}
$$

Since the noise sources are spread over the Nyquist bandwidth of the controller, the noise spectral density (in  $\lceil \frac{V}{\sqrt{U}} \rceil$  $\frac{v}{\sqrt{Hz}}$ ]) can be written as in Equation [4.5](#page-14-4).

<span id="page-14-4"></span>
$$
e_{nADC} = \frac{\frac{V_{FS}}{2\sqrt{2}}}{10^{\frac{SNR_{ADC}}{20}}\sqrt{\frac{f_s}{2}}}
$$
(4.5)

The minimum number of bits required for the ADC depends on the required SNR of the ADC (See Equation [4.3\)](#page-14-5). Because the implementation of the analyser in hardware is not covered in this thesis (See Chapter [7\)](#page-29-0), it is not possible to determine what the minimum SNR of the ADC must be. **Implementation**

For implementation, the Red Pitaya has an ADC which has the proper characteristics. It has 14 bits resolution, and a sampling frequency of 125 MHz. The value of  $SNR_{ADC}$  can be found the datasheet of the Red Pitaya. It usually depends on the frequency of the input signal and the full-scale input. Usually, some circuitry is implemented before the input signal enters the ADC. The total equivalent noise of this circuit needs to be calculated and added to the ADC noise.

# <span id="page-15-0"></span>**4.2. Digital down conversion**

The ADC module described above will have a high sampling rate to operate under the requirement of a frequency up to 27.4 MHz. However, the frequency band of interest occupies only a small part of the whole frequency range. This is were the Digital Down Converter (DDC) appears. The DDC has two main functionalities. First of all, it places the frequency band of interest, 26.9 MHz to 27.4 MHz, to base band (0 to 0.5 MHz). Secondly, it reduces the sampling rate of the input with a decimation factor  $R$ . This block is essential in the analysing chain since it decreases the needed hardware requirements to do further steps in the chain. No useful signal information will be lost, but the total analyser algorithm execution time will be lowered. The block diagram of the digital down converter can be seen in Figure [4.1](#page-15-1). This structure is commonly used in practise for digital applications[[16\]](#page-55-10) [\[18](#page-56-0)].

<span id="page-15-1"></span>

Figure 4.1: Block diagram of the DDC

#### **Frequency mixing**

The first step in the chain is the down-conversion of the frequency range of interest to base band. In order to do this, the input signal is multiplied with a complex sinusoid with a certain frequency. This oscillator frequency depends on the desired frequency shift. This can be seen in Figure [4.2.](#page-16-0) In the figure, the mixing frequency is  $f_{low} = f_{mix}$ . The operation results in down-converted signal. The sampled signal will be mixed with in-phase and quadrature-phase components to shift the frequency range of the signal to base band. These mixing sine and cosine functions will be provided by the digital local oscillator. The mixing operation can easily be understood using a sinusoidal input with frequency  $f_1$ , as illustrated in Equation [4.6](#page-15-2) and [4.7](#page-15-3). In the case of this project,  $f_{high}$  = 27.4 MHz,  $f_{low} = f_{mix}$  = 26.9 MHz and the width of the band after mixing is 0.5 MHz.

<span id="page-15-2"></span>
$$
\sin f_1 \sin f_2 = \frac{1}{2} [\cos (f_1 - f_2) - \cos (f_1 + f_2)] \tag{4.6}
$$

<span id="page-15-3"></span>
$$
\sin f_1 \cos f_2 = \frac{1}{2} [\sin (f_1 + f_2) - \sin (f_1 - f_2)] \tag{4.7}
$$

<span id="page-16-0"></span>

Figure 4.2: The input spectrum and output spectrum of the mixer.

#### **NCO**

The local oscillator or Numerically Controlled Oscillator (NCO) can be implemented using multiple architectures. Roughly, two types are used a lot in practice, the look-up table (LUT) or ROM architecture and the CORDIC algorithm architecture [\[8\]](#page-55-12). Both implementations have their advantages. The CORDIC can offer high precision results, and it uses less hardware than the LUT NCO. Also, it requires a smaller LUT than the ROM implementation. Both techniques require an additional clock, however, the CORDIC clock can be synchronized easier. Therefore, the CORDIC algorithm is chosen as the NCO implementation for this project.

#### **CORDIC NCO**

The mathematical description of the CORDIC algorithm can be found in Appendix [B.2](#page-36-0). The CORDIC algorithm can rotate a complex vector  $p$  by an angle  $\phi$  to get vector  $p'$ . This is done using only add, subtract and shift operations. The coordinates of the vectors can be written as seen in Equation [4.8.](#page-16-1)

<span id="page-16-1"></span>
$$
\begin{bmatrix} x' \\ y' \end{bmatrix} = \begin{bmatrix} \cos \phi & -\sin \phi \\ \sin \phi & \cos \phi \end{bmatrix} \cdot \begin{bmatrix} x \\ y \end{bmatrix}
$$
 (4.8)

The question remains how the CORDIC theory can be applied in order to realize an NCO. From the theory in Appendix [B.2](#page-36-0), it becomes clear that the algorithm can transform a complex number  $p$  to another complex number  $p'$  without the use of multipliers. More specifically, when the input  $\begin{bmatrix} x \\ y \end{bmatrix}$  $\begin{bmatrix} x \\ y \end{bmatrix} =$ 1 0 ] is

used in Equation [4.8,](#page-16-1) the output of the algorithm is  $\begin{bmatrix} x' \\ y' \end{bmatrix}$  $\begin{bmatrix} x' \\ y' \end{bmatrix} = \begin{bmatrix} \cos \phi \\ \sin \phi \end{bmatrix}$  $\frac{\cos \varphi}{\sin \varphi}$ . This means it is possible to create sinusoids without having to use any multipliers. Also, only a small LUT is required. The values that need to be stored into the LUT are the values for  $\phi_i$  for different iterations, as can be seen in Equation [B.19.](#page-37-0) The first 5 iterations of the CORDIC algorithm with their angle values which need to be stored in

the LUT can be seen in Table [4.1.](#page-17-0)

| Iteration i | Angle [radians]          | Angle [degrees] | $\tan \phi_i$ |
|-------------|--------------------------|-----------------|---------------|
|             | $tan^{-1}(2^0)$          | 45.0000         |               |
|             | $(2^{-1})$<br>$tan^{-1}$ | 26.5651         | 1/2           |
| 2           | $\tan^{-1}(2^{-2})$      | 14.0362         | 1/4           |
| 3           | $(2^{-3})$<br>$tan^{-1}$ | 7.12507         | 1/8           |
|             | tan                      | 3.57633         | 1/16          |

<span id="page-17-0"></span>Table 4.1: First 5 iterations of the CORDIC algorithm with their angle values for the LUT.

The last step needed before implementing the CORDIC based NCO is to define the input angle  $\phi$  of the CORDIC processor, which is the phase of the desired sinusoid. The definition of the phase can be seen in Equation [4.9](#page-17-1). If the phase is written in this way, only an addition is needed.

<span id="page-17-1"></span>
$$
\phi[n] = \frac{f_{sig}}{f_s} n = \phi[n-1] + \frac{f_{sig}}{f_s} \tag{4.9}
$$

Actually, the units of  $\phi[n]$  are rotations around the unit circle. This number can be represented with an integer part and a fraction. Since the integer number of rotations is not important, only the fraction part is considered. If the fraction is written in bits, the quadrant can be derived from the two Most Significant Bits (MSB). This is needed for the pre-rotation explained in the theory. The final block diagram for the CORDIC NCO can be seen in Figure [4.3.](#page-17-2) The mixing of the signal will also take place in this block. The phase input  $\phi$  of the CORDIC block can be represented as in Figure [4.4](#page-17-3).

<span id="page-17-2"></span>

Figure 4.3: The block diagram of the CORDIC NCO.

<span id="page-17-3"></span>

Figure 4.4: The phase input of the CORDIC NCO.

#### **CIC filter**

The CIC filter is used for the decimation of the base band signal. This implementation for the decimation of the signal offers many advantages. For example, high decimation rates can be achieved within the filter. Furthermore, it has a steep cut off, even if only a few stages are used. Lastly, it is well suited for hardware implementations, since it only uses adders and delays. An  $N$ th order CIC filter uses  $N$ integration stages and  $N$  comb stages. The transfer function of these stages combined can be seen in Equation [4.10](#page-18-0). In this equation,  $R$  is the decimation factor and  $M$  is the differential delay of the comb stages, which is usually limited to 1 or 2. For this project, unity will be selected as the differential delay.

<span id="page-18-0"></span>
$$
H(z) = H_I^N(z)H_C^N(z) = \frac{(1 - z^{-RM})^N}{(1 - z^{-1})^N} = \left(\sum_{k=0}^{RM-1} z^{-k}\right)^N
$$
\n(4.10)

The magnitude response of the filter for large R can be written as seen in Equation [4.11.](#page-18-1) An example of the magnitude response of a 4th order CIC filter with a decimation factor  $R$  of 10 can be seen in Figure [4.5](#page-18-2).

<span id="page-18-1"></span>
$$
|H_{CIC}(f)| \approx |RM \frac{\sin(\pi M f)}{\pi M f}|^N
$$
\n(4.11)

<span id="page-18-2"></span>

Figure 4.5: Magnitude response in dB of a 4-stage CIC filter with a decimation factor  $R$  of 10.

#### **FIR filters**

The CIC decimation filter usually lacks a wide, flat band-pass. Therefore, it is wise to construct a solution to overcome the magnitude droop. Many solutions can be implemented to overcome this problem. For example, an FIR filter with a magnitude response inverse of that of the CIC filter can be implemented. However, since the design will have a hardware implementation, it is wise to choose a solution which needs minimal hardware requirements. Therefore, a cosine based CIC filter compensator is used[[4](#page-55-13)]. This filter uses only three coefficients and does not need any multipliers. The FIR magnitude response can be written as in Equation [4.12.](#page-18-3)

<span id="page-18-3"></span>
$$
H_{FIR1}(z^M) = \begin{cases} (2^{-4}[z^{-R} - (2^4 + 2)z^{-2R} + z^{-3R}])^N, & \text{for } 1 < N \le 3\\ (2^{-4}[z^{-R} - (2^4 + 2)z^{-2R} + z^{-3R}])^{N-1}, & \text{for } N > 3 \end{cases}
$$
(4.12)



**Magnitude response of a 4-stage CIC filter with decimation factor 125**

Figure 4.6: Magnitude response in dB of a compensated 4-stage CIC filter with a decimation factor R of 125.

The second FIR filter can be used as a shaping filter. This filter is used to improve the passband and stopband characteristics, like ripples and transition width. By changing the coefficients of the filter, the desired filter characteristic of the given application can be obtained.

#### **4.2.1. DDC noise**

The first computation that is done is the mixing of sine and cosine signals with the input signal to downconvert the frequency to the desired frequency band. After this mixing operation, the result is rounded. Next, the signal is decimated with the desired factor and filtered.

Because of this decimation, the final Nyquist bandwidth at the output of the converter can be written as in Equation [4.13](#page-19-0) [[16](#page-55-10)]. In this equation,  $D$  is the decimation factor and  $f_s$  the sampling frequency.

<span id="page-19-0"></span>
$$
N_{BWfinal} = \frac{f_s}{2D} \tag{4.13}
$$

Because of this downsampling and filtering, the white noise power will reduce and the SNR at the output of the system will improve. This is referred to as processing gain in literature, which can be seen in Equation [4.14.](#page-19-1)

<span id="page-19-1"></span>
$$
P_g = 10 \log \frac{\frac{f_s}{2}}{N_{BWfinal}} \tag{4.14}
$$

#### **NCO noise**

Next, the noise spectral density of the Numerically Controlled Oscillator (NCO), which produces the sine and cosine waves at the desired frequency, can be computed. This is done in a similarly as with the ADC and can be seen in Equation [4.15](#page-19-2).

<span id="page-19-2"></span>
$$
e_{nNCO} = \frac{\frac{V_{FS_{NCO}}}{2\sqrt{2}}}{10^{\frac{SNR_{NCO} + P_g}{20}}\sqrt{N_{BWfinal}}}
$$
(4.15)

If the signal from the ADC is  $N$  bits wide, and the signal from the NCO is  $P$  bits wide, the signal at the output of the mixer will be  $N + P$  bits wide. In practice, this signal will be rounded such that M bits remain, in order to do further operations efficiently. This rounding will introduce an error. If it is assumed that the error has a rectangular, or uniform distribution [\[16](#page-55-10)], the noise voltage can be written as in Equation [4.16.](#page-20-1)

<span id="page-20-1"></span>
$$
V_{round1} = \frac{2^{-M}}{\sqrt{12}}
$$
 (4.16)

The voltage noise spectral density of the rounding can be seen in Equation [4.17](#page-20-2).

<span id="page-20-2"></span>
$$
e_{n_{round1}} = \frac{V_{round1}}{\sqrt{\frac{f_s}{2}}}
$$
(4.17)

#### **Filtering noise**

The DDC consists of three filters, a CIC decimation filter and two FIR filters. The main source of noise in the CIC filter stages comes from the rounding of the output of the CIC filter. This is done for similar reasons and in a similar way as with the mixing. The noise voltage  $V_{round2}$  is written similarly. The noise spectral density due to this rounding can be written as in Equation [4.18,](#page-20-3) where  $N_{CL}$  is the decimation factor of the CIC filter.

<span id="page-20-3"></span>
$$
e_{n_{round2}} = \frac{V_{round2}}{\sqrt{\frac{f_s}{2N_{CIC}}}}
$$
(4.18)

The quantization of the FIR filter coefficients introduces new noise in the system. For  $N$  symmetrical coefficients,  $(N + 1)/2$  coefficients need to be quantized. The same number of multipliers are needed. The multiplication introduces rounding error. It is assumed that the multipliers are uncorrelated and the noise has a uniform distribution. The RMS FIR noise voltage is given in Equation [4.19](#page-20-4)

<span id="page-20-4"></span>
$$
V_{FIR} = \sqrt{\frac{N+1}{2}} V_{round,multiplier}
$$
 (4.19)

The noise spectral densities of FIR 1 and FIR 2 are given in Equations [4.20](#page-20-5) and [4.21,](#page-20-6) where  $N_{FIR1}$  is the decimation factor of the first FIR filter.

<span id="page-20-5"></span>
$$
e_{n_{FIR1}} = \frac{V_{FIR1}}{\sqrt{\frac{f_s}{2N_{CIC}}}}
$$
(4.20)

<span id="page-20-6"></span>
$$
e_{n_{FIR2}} = \frac{V_{FIR2}}{\sqrt{\frac{f_s}{2N_{CIC}N_{FIR1}}}}
$$
(4.21)

#### **Total DDC noise**

The total noise of the DDC can be found by adding the spectral densities. This total noise is uniformly distributed. The noise expression can be seen in the block diagram in Figure [4.7.](#page-20-7)

<span id="page-20-7"></span>

Figure 4.7: Block diagram of the DDC noise sources.

From this figure, the total noise spectral density of the DDC can be derived as given in Equation [4.22.](#page-20-8)

<span id="page-20-8"></span>
$$
e_{n_{DDC}} = 2\sqrt{G_{FIR2}^2(e_{n_{FIR2}}^2 + G_{FIR1}^2(e_{n_{FIR1}}^2 + e_{n_{round2}}^2 + (N_{ClC}^P(e_{n_{round1}}^2 + \frac{1}{2}e_{n_{NCO}}^2))))}
$$
(4.22)

<span id="page-20-0"></span>Where P is the order of the CIC filter and  $G_{FIR1}$  and  $G_{FIR2}$  are the gain factors of the FIR filters.

### **4.3. DDC testing**

For testing the DDC, an input signal with a peak frequency at 27.1 MHz is used. The mixing operation is performed with a frequency of 26.9 MHz. The means that the original band of 26.9 to 27.4 MHz is transformed to 0 to 0.5 MHz. Therefore, the frequency peak after the DDC is expected to be at 0.2 MHz. From Figure [4.8](#page-21-0), it becomes clear that the frequency downconverting and downsampling operations work as expected.

<span id="page-21-0"></span>

Figure 4.8: Frequency spectrum before the DDC (left) and spectrum after DDC (right).

 $\frac{1}{\sqrt{2}}$ 

# <span id="page-22-0"></span>Frequency domain computations

This chapter describes the design steps of the frequency domain computations for finding the peak resonance frequency of the reader circuit. These include performing a Fourier transform and spectrum polynomial interpolation.

### <span id="page-22-1"></span>**5.1. Fast Fourier Transform**

The fast Fourier transform (FFT) is a mathematical tool used to determine the frequency content of a signal. The FFT of a signal with length  $N$  is calculated according to Equation [5.1](#page-22-2).

<span id="page-22-2"></span>
$$
X[k] = \sum_{n=0}^{N-1} x[n]W_N^{kn} = \sum_{n=0}^{N/2-1} x[2n]W_{N/2}^{kn}W_N^k + \sum_{n=0}^{N/2-1} x[2n+1]W_{N/2}^{kn}
$$
(5.1)

With each  $\mathcal{W}_N^{nk}$  representing a frequency bin.

$$
W_N^{nk} = e^{-j2\pi(kn)/N} \tag{5.2}
$$

Thus ah FFT of length  $N$  produces  $N$  different frequency bins. Therefore, the longer signal length, the smaller the size of the frequency bins of the FFT, and the higher the resolution. However, the speed of the weighing belt sets a constraint in the maximum length of the Fourier transform. Given that the belt moves a speed of  $v_{belt}$  = 2 m/s and a sensor length  $l_{sensor}$  of 2 cm, the maximum time slot in which a detection must be made is:

$$
t_{measurement} = \frac{l_{sensor}}{v_{belt}} = \frac{2cm}{2m/s} = 10ms
$$
\n(5.3)

The number of measurements within the time slot depends on the conditions in which the measurement is performed. Mechanical vibrations of the conveyor belt are in the order of Hz. These vibrations can, therefore, be assumed constant throughout a 10 ms period. It is therefore chosen to perform a single measurement in a single passing of the load cell. The equates to an FFT length of:

$$
L = t_{measurement} \cdot f_s = 10ms \cdot 1MHz = 10000 samples \tag{5.4}
$$

An important constraint for the FFT to operate properly is that the time calculate the FFT of signal must be less than a sampling period of the down sampled system. If this is the case and no time buffer for calculating Fourier transforms is needed, a real-time system can be implemented. Thus the computation time must be less than 1  $\mu$ s.

#### **Windowing**

Discontinuities might occur at the boundaries of the framed inputs. However, due to the self-windowing properties of noise burst[[7](#page-55-3)], no spectral leakages will occur.

#### <span id="page-23-0"></span>**5.2. FFT noise analysis**

#### **FFT bin noise power**

<span id="page-23-1"></span>The FFT block receives an input vector  $\vec{x}$  that contains N samples. The FFT block outputs  $\vec{X}$ , the frequency domain representation of  $\vec{x}$ .



Figure 5.1: FFT input and output diagram

The input vector  $\vec{x}$  can be split up into two parts, the signal part  $\vec{y}$  and the noise part  $\vec{z}$ . The noise part  $\vec{z}$  is equal to the additive noise  $V_n$  from Figure [5.1](#page-23-1), so it is a random variable with a uniform distribution, variance (noise power)  $V_n^{\phantom{2} 2}$  and a zero mean. The FFT of  $\vec{x}$  is given in Formula [5.5.](#page-23-2)

<span id="page-23-2"></span>
$$
X_k = \sum_{n=0}^{N-1} x_n e^{-\frac{j2\pi}{N}kn}
$$
\n(5.5)

Since the FFT is a linear operation the output vector may also be split up in a signal part  $\vec{Y}$  and a noise part  $\vec{Z}$ .

All entries of  $\vec{z}$  are uniformly distributed and independent variables. The sum of uniform distributed variables has an Irwin-Hall distribution. For large sums, the distribution approximates a normal distribution, for which holds that variances of individual independent elements can be added up. The summation over the random variables in  $\vec{z}$  can be split up into a real and an imaginary part, as shown in Equation [5.6.](#page-23-3)

<span id="page-23-3"></span>
$$
Z_k = \sum_{n=0}^{N-1} z_n \cos\left(-\frac{2\pi}{N}kn\right) + j\sum_{n=0}^{N-1} z_n \sin\left(-\frac{2\pi}{N}kn\right)
$$
(5.6)

The variance of a scaled random variable holds  $Var[aX] = a^2Var[X]$  so the total noise expression for  $Z_k^2$  is given by Equation [5.7](#page-23-4).

<span id="page-23-4"></span>
$$
Z_k^2 = \sum_{n=0}^{N-1} z_n^2 \cos^2\left(-\frac{2\pi}{N}kn\right) + j\sum_{n=0}^{N-1} z_n^2 \sin^2\left(-\frac{2\pi}{N}kn\right) \tag{5.7}
$$

When N is large the cos (...) and sin (...) expression will be sampled throughout in the domain  $[0, 2\pi]$ . The average value of this sampled value can be found by integrating  $cos(\theta)$  from 0 to  $2\pi$  and dividing by  $2\pi$ , which is equal to 0.5. For large N the sum for  $Z_k^2$  (the FFT bin noise power) converges to Equation [5.5](#page-23-2).

#### **Scaling the FFT**

When the FFT input and output length is increased from  $N_0$  to  $N_1$  the output noise power will only increase by a factor of  $\frac{N_1}{N_0}$ . This means that the total signal to noise ratio is increased by a factor of  $\frac{N_1}{N_0}$ . So for every doubling of the FFT length 3db of signal to noise ratio is added, assuming that the signal and noise stay constant in the added measurement time.

### <span id="page-24-0"></span>**5.3. Interpolation**

#### **Limitations in the bandwidth**

Due to law restrictions in the frequency usage, the bandwidth might be a constraint in the design of the analyser. The bandwidth itself cannot create enough frequency resolution for the required number of steps. Interpolation between frequency bins will increase the frequency resolution of the analyser (see Chapter [3](#page-9-0)).

#### **Polynomial interpolation**

Polynomial interpolation will fit a polynomial given in Equation [5.8](#page-24-1) between the set of data points with a minimum mean square error.

<span id="page-24-1"></span>
$$
X_k = \beta_0 + \beta_1 \omega_k + \beta_2 \omega_k^2 + \dots + \beta_m \omega_k^m + \epsilon_k \tag{5.8}
$$

$$
\begin{bmatrix} X_0 \\ X_1 \\ X_2 \\ \vdots \\ X_{N-1} \end{bmatrix} = \begin{bmatrix} 1 & \omega_0 & \omega_0^2 & \dots & \omega_0^m \\ 1 & \omega_1 & \omega_1^2 & \dots & \omega_1^m \\ 1 & \omega_2 & \omega_2^2 & \dots & \omega_2^m \\ \vdots & \vdots & \vdots & \ddots & \vdots \\ 1 & \omega_{N-1} & \omega_{N-1}^2 & \dots & \omega_{N-1}^m \end{bmatrix} \begin{bmatrix} \beta_0 \\ \beta_1 \\ \beta_2 \\ \vdots \\ \beta_m \end{bmatrix} + \begin{bmatrix} \epsilon_0 \\ \epsilon_1 \\ \epsilon_2 \\ \vdots \\ \epsilon_{N-1} \end{bmatrix}
$$
 (5.9)

The shorter matrix representation is given by  $\vec{X} = \Omega \vec{B} + \vec{\epsilon}$ . The solution for  $\vec{B}$  that minimizes the mean squared error is given in Equation [5.10.](#page-24-2)

<span id="page-24-2"></span>
$$
\vec{\beta} = (\Omega^T \Omega)^{-1} \Omega^T \vec{X} \tag{5.10}
$$

From Equation [5.10](#page-24-2) it clear that the estimates for  $\beta$  are linearly dependent on  $\vec{X}$ , so  $\beta$  can be written as a combination of  $\vec{\lambda}$ , the actual coefficients for the fitted polynomial and  $\vec{\zeta}$ , a vector of normally distributed random variables that represent the estimation error.

#### **Parameters of interpolation**

Furthermore, there is a trade-off in the order of interpolation. High orders of interpolation coincide with a large computational complexity. On the other hand, low orders of interpolation will result in inaccurate interpolation.

The region to interpolate over should not be the entire spectrum. Rather, only samples in the neighbourhood of the peak should be taken into account with the interpolation. By accurately observing the impedance response of the reader circuit[[7](#page-55-3)], a peak width of 2.5 kHz was found, which translates to 500 samples for a measurement time of 10 ms.

#### **Determining the resonance frequency**

When Equation [5.8](#page-24-1) is applied to the Fast Fourier transform of Equation [5.1](#page-22-2), the resonance frequency can be found by computing the maximum of the interpolated function.

$$
F = max(P(x))
$$
\n(5.11)

<span id="page-24-3"></span>Next, the resonance frequency is rounded off the nearest frequency bin with resolution *. Figure [5.2](#page-25-0)* shows a simulation of interpolating in between the frequency bins. Numerical results are shown in Table [5.1.](#page-24-3) The consistency of the interpolation will be tested in Chapter [6](#page-26-0).

Table 5.1: Results of a test of the interpolating algorithm.



<span id="page-25-0"></span>

Figure 5.2: An overview of frequency interpolation at a frequency of 200 000 Hz. (This is a downconverted frequency which corresponds to a frequency of 27.1 MHz in the frequency domain of 26.9-27.4 MHz.)

#### **Low pass filtering**

With testing the interpolation function in MATLAB, the signal over which was interpolated contained noisy spikes in the frequency spectrum, which caused false detections of the resonance frequencies (see Figure [5.3](#page-25-1)). This problem can be solved by using a low pass filter before interpolating the data. Before filtering, spikes with relative height higher than 5% of the signal maximum are removed from the data.

The low pass filter has such a characteristic that it filters with a normalised passband frequency of  $\omega_{pass}$ and attenuates with 60dB in the stopband. There is a trade-off in the choice of  $\omega_{pass}$ : the frequency must not be too high or the filter will not remove the noise significant enough. On the other hand, choosing a too low  $\omega_{pass}$  will result in unnecessary loss of information. With an  $\omega_{pass}$  of 0.1, the filter operates optimally. The result is a more smooth frequency spectrum (see Figure [5.3](#page-25-1)).

<span id="page-25-1"></span>

Figure 5.3: Frequency spectrum with noisy spikes (left) and filtered spectrum after (right). This is a downconverted frequency which corresponds to a frequency of 27.1 MHz in the frequency domain of 26.9-27.4 MHz.

# <span id="page-26-0"></span>System testing and implementation

In order to validate if the designed system is able to satisfy the requirements, an implementation needs to be made. This is also stated in the requirements, as can be seen in Requirement [FR-ToR02](#page-7-3) and [FR-ToR03.](#page-7-4) First of all, a MATLAB simulation of the system is made.

### <span id="page-26-1"></span>**6.1. Testing for accuracy and precision**

In the test case, 40 detections of a 27.1MHz resonance frequency in the reader circuit are performed. The result is shown in Figure [6.1](#page-26-2).

<span id="page-26-2"></span>

Figure 6.1: Detection samples of the analyser at input 27100100 Hz

Table 6.1: Analyser statistics of 40 detections of 27.1MHz resonance frequency at 50 Hz resolution

<span id="page-26-3"></span>

|    |          | $^{\backprime}$ Sample size $\mid$ Sample mean $\mid$ Accuracy [Hz] $\mid$ Sample variance [Hz] ( $\sigma^{2})$ | <b>Sample standard</b><br>deviation ( $\sigma$ ) | <b>Hit ratio</b>          |
|----|----------|-----------------------------------------------------------------------------------------------------------------|--------------------------------------------------|---------------------------|
| 40 | 27100078 | 6147                                                                                                            | 78.4                                             | $\frac{6}{1}$ = 20%<br>40 |

Table [6.1](#page-26-3) shows the variance, and the average of the results, from this, the accuracy and precision of the analyser have been calculated. From these results, it can be observed that the accuracy of the analyser is smaller than half the desired resolution, which is sufficient. The variance, however, is too large to have 50 Hz output resolution. Moreover, the hit ratio is only 20%, meaning that the probability of a correct outcome is 0.2. The constraint given by Equation [3.3](#page-12-1) in Chapter [3](#page-9-0) states is not met:

$$
f_{offset} + 3\sigma = 257.2 \ll R/2
$$
\n(6.1)

Table [6.2](#page-27-0) shows the test results with a resolution of 100 Hz, which will result in 5000 discrete levels of resonance frequencies. With a hit ratio of 45%, the analyser will still not be precise enough.

<span id="page-27-0"></span>

|     |          |    | Sample size   Sample mean   Accuracy [Hz]   Sample variance [Hz] $(\sigma^2)$ | Sample standard<br>deviation ( $\sigma$ ) | <b>Hit ratio</b>            |
|-----|----------|----|-------------------------------------------------------------------------------|-------------------------------------------|-----------------------------|
| -40 | 27100223 | 23 | 12405                                                                         | 109                                       | 18<br>$\frac{18}{10}$ = 45% |

Table 6.2: Analyser statistics of 40 detections of 27.1MHz resonance frequency at 100 Hz resolution

Finally, the analyser is tested with a resolution of 500 Hz, which is required to achieve the minimum number of 1000 discrete levels in the weighing industry for a viable product. Fortunately, the hit ratio of this test was 100 %, thus the analyser is 100% accurate with 0 variance at this resolution.

#### **Signal to noise ratio**

The SNR of the system test was around 20 dB. When comparing the obtained value for  $3\sigma$  with the SNR table in Chapter [3](#page-9-0), this result is expected. The reason for choosing this SNR is due to an error in the MATLAB code. This resulted in the generation of excess noise by the DDC, which will further be discussed in Chapter [7.](#page-29-0)

At this signal to noise ratio, the maximum achievable resolution with 100% hit rate is 250 Hz.

### **Testing changes in resonance frequency**

In order to validate the functionality of the analyser, the following test case has been set up: To test a single passing of a load cell over the reader circuit. In the test case, the input of the analyser are consists of signals with 50 Hz difference in resonance frequency, starting from 27.1MHz. The test is successful if the analyser is able to detect the changes in the signal. The following is assumed:

- The over passing time of the load cell is 10 ms.
- The average coupling factor of the sensor to the reader circuit is 0.3.  $<sup>1</sup>$  $<sup>1</sup>$  $<sup>1</sup>$ </sup>

Figure [6.2](#page-27-2) shows the frequency response resonance response for the reader circuit at 27.1MHz. From Equation [6.2,](#page-28-1) it is derived that a 50Hz change in resonance frequency may be approximated by changing the capacitance in the sensor by 0.2 fF (See Appendix [D.1](#page-41-1) for exact values of the sensor). This is done by linear approximation.

<span id="page-27-2"></span>

Figure 6.2: Frequency response of the reader circuit at 27.1MHz

<span id="page-27-1"></span><sup>&</sup>lt;sup>1</sup> In practice, the coupling factor will variate during the 10 ms passing of the load cell. For the first test case, this phenomena has been ignored, and an average coupling factor has been chosen.

The values for the inductors and capacitor in the reader and sensor circuit to simulate the resonance frequency are found in Appendix [D.1](#page-41-1)

<span id="page-28-1"></span>
$$
f_{res} = \frac{1}{2\pi LC} \tag{6.2}
$$

#### **Results**

Table [6.3](#page-28-2) shows the simulation results of the test case. The data indicates that the analyser is capable of estimating the resonance frequency with an accurately of 50Hz. However, errors occur frequently in the data. The error at most one frequency bin. Therefore, the desired 50 Hz output resolution is not met.

<span id="page-28-2"></span>

| <b>Input frequency [Hz]</b> | <b>Frequency bin [Hz]</b> | Est. frequency bin [Hz] | Error [bins] | Error [Hz] |
|-----------------------------|---------------------------|-------------------------|--------------|------------|
| 27100013                    | 27100000                  | 27100000                |              | U          |
| 27100065                    | 27100050                  | 27100050                |              | 0          |
| 27100117                    | 27100100                  | 27100100                |              | 0          |
| 27100170                    | 27100150                  | 27100150                |              | 0          |
| 27100222                    | 27100200                  | 27100150                |              | 50         |
| 27100274                    | 27100250                  | 27100200                |              | 50         |

Table 6.3: Simulation results for the total system testing.

# <span id="page-28-0"></span>**6.2. Hardware implementation**

After validating the results with MATLAB, a hardware implementation can be made. The first block in the system is the ADC. Therefore, an ADC with the right parameters should be picked for the system. The minimum sampling frequency should be 54.8 MHz, as explained before. To come to a right ADC choice, order parameters, like the number of bits and the SNR of the ADC should be taken into account. With the minimum required SNR specified, these parameters can be filled in into the noise equations to check if the chosen ADC is acceptable. Noise sources added by circuitry around the ADC should be taken into account as well.

The DDC block can be realized using an FPGA board[[18\]](#page-56-0). In this case, the noise equations can be filled in too. It is possible to implement the DDC using VHDL code. VHDL code is easily generated using the MATLAB tool; HDL Coder. This tool converts MATLAB code and Simulink diagrams into HDL code.

The last two blocks, the FFT and spectrum interpolation can be done on a processor, using C for instance.

<span id="page-28-3"></span>When combining the needed hardware, handheld FPGA boards with additional hardware appear to be a reasonable choice for prototyping. A good example of this is the Red Pitaya STEMLab 125-14 board [\[14](#page-55-14)]. Some relevant parameters and features of this board are summarized in Table [6.4](#page-28-3). The SNR of the ADC on this board 73 dB, which is well above 60 dB [\[15](#page-55-15)].

| FPGA                    | FPGA Xilinx Zyng 7010 SOC         |
|-------------------------|-----------------------------------|
|                         |                                   |
| Processor               | Processor DUAL CORE ARM CORTEX A9 |
| Sampling rate           | 125 MS/s                          |
|                         |                                   |
| ADC bits                | 14                                |
| Communication protocols | $ $ I2C, SPI, UART                |
|                         |                                   |

Table 6.4: Red Pitaya STEMLab 125-14 features [\[14](#page-55-14)].

# 7 **Discussion**

# <span id="page-29-1"></span><span id="page-29-0"></span>**7.1. Requirements**

The requirements provided by Intralox were set up, aiming to deliver a physical prototype. However, due to the COVID-19 pandemic, building and performing tests on physical prototypes was prohibited throughout the BAP period. This affected the progress of the project. Most of the requirements have not been passed completely as no physical testing has been performed.

- **Requirement [FR-MR01](#page-7-2)**: The requirement to be able to detect 10 000 discrete evenly spaced levels of signal frequency has not been completed. As stated in the results of system testing [6](#page-26-0), the output resolution of 50 Hz is not met consequently. However, this was due to an SNR that is too low for proper frequency estimation. When the SNR is enlarged, this requirement will be met, as can be read in Chapter [3](#page-9-0).
- **Requirement [FR-ToR01](#page-7-5)**: The processing time of 10 ms could not be tested. This was due to a combination of factors. First of all, due to the COVID-19 situation, producing a real-life prototype was not allowed. Furthermore, the Red Pitaya test-board arrived too late, such that not enough time for writing testing VHDL code was left. This requirement can easily be verified when the hardware application is made.
- **Requirement [FR-ToR02](#page-7-3)**: The system is simulated in MATLAB. Therefore, this requirement is satisfied. However, extra work is needed for some parts of the code, as the DDC generated excess noise in the code.
- **Requirement [FR-ToR03](#page-7-4)**: The system is not implemented and simulated in VHDL or other HDL for the same reasons as for Requirement [FR-ToR01.](#page-7-5) However, as stated before, when using MATLAB HDL coder, the VHDL code can be generated.
- **Requirement [FR-ToR04](#page-7-6)**: The system can communicate with a PC when the Red Pitaya implementation is made.

# <span id="page-29-2"></span>**7.2. Sensor bandwidth**

The analyser team has designed the analyser according to the design requirements of Intralox, see Chapter [2.](#page-7-0) This implies that the resonance frequency of the sensor circuit will change between 26.9 MHz and 27.4MHz by 0.2mm deformation. However, in practice, the sensor will only resonate between 27.1 MHz and 27.405MHz. This can also be seen from Requirement [IF1-MR03.](#page-40-0) Thus for the practical implementation of the system, the analyser must be tuned to this bandwidth. A consequence of the smaller bandwidth is that a higher resolution and therefore a higher SNR in the analyser is required.

# <span id="page-30-0"></span>**7.3. System testing with a time-varying coupling factor**

The system test in Chapter [6](#page-26-0) assumed a constant coupling factor. However, in practice, the coupling factor will change throughout a measurement cycle. Although the average coupling factor of the actual movement might approximately be 0.3 as used in the test case, the effective measurement time will not be 10 ms. With little to no coupling, the signal contains insufficient information to contribute to a This will have a significant effect possible resolution in the FFT bins (See Equation [3.2](#page-10-2) in Chapter [3\)](#page-9-0).

Attempts have been made to create a test signal in MATLAB, which has a time-varying coupling factor. However, due to the complexity of the problem and short project time, no successful simulation has been performed. Thus in practice, test data must be collected by physically moving the load over the reader circuit with a speed of 2 m/s.

# <span id="page-30-1"></span>**7.4. Linear approximation of the frequency changes**

The capacitive change in the sensor has only been simulated for the maximal deformation of 0.2 mm[[7](#page-55-3)]. Thus, no information about the linearity between levels of deformation and changes in resonance frequency is known. Therefore, it is questionable whether the linear resolution scale used in the analyser is compatible with the sensor.

8

# <span id="page-31-0"></span>Conclusion and Recommendations

# <span id="page-31-1"></span>**8.1. Conclusion**

To conclude, an analyser system has been designed in an attempt to improve the previous efforts by Intralox in designing an in-situ conveyor belt weighing system.

A block diagram has been constructed as a result of a functional analysis of the analyser. The block diagram for the analyser consists of an analog to digital converter, digital down converter and a polynomial interpolation unit.

Next, an analysis of the required precision of the analyser is developed from which a minimum signal to noise ratio is calculated. In addition, the analysis provided insight in limits of the variance and offset in the detections of the analyser, such that an accurate and precise design could be made. Moreover, quantization noise due to finite precision in digital signal processing is the most significant noise source of the analyser. Quantization noise increases the variance of the detection output of the analyser and reduces the analyser precision. Other parts of the weighing system, such as the sensor, require calibration with test weights to minimise the offset as much as possible.

Subsequently, the components of the block diagram were elaborated. Models for determining the signal to noise ratio of the ADC have been created, as well as constraints in the sampling frequency. The design of the DDC was finalised by subdividing the DDC into smaller components. The DDC places the frequency band of interest to base-band, and it reduces the sampling rate. The numerical oscillator (NCO) of the DDC has been implemented using a CORDIC algorithm. With this, the input signal could be mixed with a digital sine/cosine function. The frequency mixer is followed by a CIC filter. This filter decimates the input by a factor  $D$ .

A compensation filter together with an FIR filter has been realised to create a flat band-pass response. The noise contribution of the DDC is mainly related to rounding of filter coefficients and the finite precision of digital filtering. The quantization errors have a uniform distribution.

After the conversions, the signal is transformed to frequency-domain using an FFT. Polynomial interpolation has been used to increase the frequency resolution. Low pass filtering over the frequency data removes unwanted spikes that may affect the interpolation and the search algorithm for the resonance frequency. The search algorithm rounds the detected frequency nearest discrete frequency depending on the resolution.

In the last part of the thesis, system testing has been applied to the analyser. Tests were performed by simulating the analyser in MATLAB. The desired frequency resolution of 50 Hz was not always obtained in the test cases because off a too low signal to noise ratio.

# <span id="page-32-0"></span>**8.2. Recommendations**

### **Sensor bandwidth**

A major show stopper in obtaining a proper resolution of the weighing system is the limited bandwidth. A high-frequency resolution, and therefore a high SNR, is required to be able to detect 10 000 levels within a bandwidth of 0.5MHz. In an interview of an RF engineer at Philips [\[7\]](#page-55-3), it became clear that the bandwidth constraint by Dutch law did not apply to the weighing belt system, because of the low power spectral densities in reader sensor coupling. This would enable the use of larger bandwidths, making it possible to detect 10 000 levels with a lower frequency resolution and a lower SNR.

### **Data aggregation on the PC**

Once a stable analyser system has been engineered, it is highly recommended to aggregate the load cell data on a PC for further processing of the data. A dynamic real-time image of the weighing belt can be constructed by periodically updating the load cell weight information. With this information, applications such as providing positional feedback of packets to the belt controller, determining the centre of gravity on packets on the belt, and parallel packet weighing can be implemented in software in the Intralox weighing belt.

### **Reader configuration for longer measurement time**

In Appendix [A,](#page-33-0) a mechanical solution in which reader circuit move along sensors is proposed to increase the measurement time.



# <span id="page-33-0"></span>Reader configurations for longer reader time

Available measurement time to read out the sensor is a show stopper variable of the resolution of an FFT. Therefore, the analyser team has come up with a belt configuration that allows for longer coupling time between the sensor and the reader to increase the measurement time.

#### **Operating mechanism**

Instead of using a single row of reader circuits, multiple reader rows can be installed to read out multiple rows of load cells. To do so, the rows of reader circuits will be placed on a rail and follow the sensor for a length of time that allows for a precise measurement of the load cell weight. During this period, the relative velocity between the sensors and the readers is zero.

Next, a servo motor reverses direction of travel to place the reader at the initial position for a new measurement. Because the weighing belt moves continuously, a second reader block is required to operate in opposite phase of movement with the first reader block. The second reader block reads out the sensor rows missed by the first block as the first block is brought back to the starting position. The cycle repeats. As the second reader block movement to the starting position, the first reader block reads out a rows of sensors.

#### **Risks and challenges**

To implement this configuration, several aspects have to be taken in to account:

- **Timing of the system:** The configuration requires a high precision in the timing of the movement in the reader blocks, since the reader blocks must be placed exactly below the sensors and must operate exactly in opposite phase of movement. Also, a constant belt speed is required.
- **Mechanical noise sources:** The configuration increases the number of moving parts in the weighing system, therefore increasing the number of sources of vibration. Therefore, mechanical engineers must design a system with as little vibration as possible. Furthermore, a longer measurement time may cause the mechanical vibrations not to be constant throught out the measurement period.

# Side view conveyor belt



Figure A.1: A reader configuration which allows for longer measurement time

# **Equations**

B

### <span id="page-35-1"></span><span id="page-35-0"></span>**B.1. Analog to digital converter**

The analog to digital converter operates at a sampling frequency  $f_s$ . The sampling period  $T_s$  is:

$$
T_s = \frac{1}{f_s} \tag{B.1}
$$

#### **Sampling function**

Sampling is done via a pulse train  $\delta_{T_S}.$ 

$$
\delta_{T_s} = \sum_n \delta(t - nT_s) \tag{B.2}
$$

**Sampled signal**

$$
x_s(t) = x(t)\delta_{T_s}(t) \tag{B.3}
$$

#### **Quantization**

**Number of Quantization levels**

Given a quantizer with  $M$  bits, the number of quantization levels  $N$  is:

$$
N = 2^M \tag{B.4}
$$

#### **Quantization step**

The quantization step Δ is the difference between two quantization levels.

$$
\Delta = \frac{2max|x(t)|}{N} \tag{B.5}
$$

#### **Quantization error**

The quantization error is the difference between the sampled and the quantized signal.

$$
\epsilon(nT_s) = x(nT_s) - \hat{x}(nT_s) \tag{B.6}
$$

The magnitude of this value is bounded by the quantization step.

$$
0 \le \epsilon (nT_s) \le \Delta \tag{B.7}
$$

From Equation [4.2](#page-14-2) it can easily be derived that the RMS value of the noise can be written as in Equation [B.8](#page-35-2).

<span id="page-35-2"></span>
$$
V_{noise_{RMS}} = \frac{\frac{V_{FS}}{2\sqrt{2}}}{10^{\frac{SNR_{ADC}}{20}}} \tag{B.8}
$$

Since the noise sources are spread over the Nyquist bandwidth of the controller, the noise spectral density (in  $\left[\frac{V}{\sqrt{n}}\right]$  $\frac{v}{\sqrt{Hz}}$ ]) can be written as in Equation [B.9](#page-36-1).

<span id="page-36-1"></span>
$$
e_{nADC} = \frac{\frac{V_{FS}}{2\sqrt{2}}}{10^{\frac{SNR_{ADC}}{20}}\sqrt{\frac{f_s}{2}}}
$$
(B.9)

#### **Frequency resolution for time harmonic signals**

The frequency resolution of the signal is sampling frequency divided by the length of the FFT:

$$
\Delta f = \frac{F_s}{L} \tag{B.10}
$$

The required sampling time for a FFT is:

$$
T_{FFT} = T_s L = \frac{L}{F_s} = \frac{1}{\Delta f}
$$
 (B.11)

Let  $n$  the number of distinguishable steps required in the frequency spectrum. The required bandwidth for the input signal is given by:

$$
B = n \cdot \Delta f = \frac{n}{T_{FFT}} \tag{B.12}
$$

The Nyquist criterion set limits to the minimal sampling frequency after down conversion:

$$
B \le \frac{F_s}{2} \tag{B.13}
$$

Thus the minimal length of the FFT is:

$$
L = \frac{F_s}{\Delta f} = 2n = 2 * B * T_{FFT}
$$
 (B.14)

#### <span id="page-36-0"></span>**B.2. CORDIC algorithm**

The COordinate Rotational Digital Computer (CORDIC) algotihm was first developed by Volder in 1959 [\[17](#page-55-16)]. It is used to iteratively compute trigonometric functions using only add, subtract and shift operations. The CORDIC algorithm can rotate a complex vector  $p$  by an angle  $\phi$ . This results in a new vector  $p^\prime$ , which can be written as

<span id="page-36-2"></span>
$$
p' = p \cdot e^{j\phi} = p(\cos\phi + j\sin\phi) \tag{B.15}
$$

Equating the definitions of  $p$  and  $p'$  in Equation [B.15](#page-36-2) gives the coordinate components of vector  $p'$ , as can be seen in Equation [B.16.](#page-36-3)

<span id="page-36-3"></span>
$$
\begin{bmatrix} x' \\ y' \end{bmatrix} = \begin{bmatrix} \cos \phi & -\sin \phi \\ \sin \phi & \cos \phi \end{bmatrix} \cdot \begin{bmatrix} x \\ y \end{bmatrix} = R \cdot \begin{bmatrix} x \\ y \end{bmatrix}
$$
 (B.16)

.

The rotational matrix R can be rewritten using  $\cos\phi=\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt{1-\frac{1}{\sqrt$  $\sqrt{1+\tan(\phi)^2}$ 

$$
R = \begin{bmatrix} \cos \phi & -\sin \phi \\ \sin \phi & \cos \phi \end{bmatrix} = \cos \phi \cdot \begin{bmatrix} 1 & -\tan \phi \\ \tan \phi & 1 \end{bmatrix} = \frac{1}{\sqrt{1 + \tan(\phi)^2}} \cdot \begin{bmatrix} 1 & -\tan \phi \\ \tan \phi & 1 \end{bmatrix} \tag{B.17}
$$

Now, the total rotation  $\theta$  between two vectors can be performed with the help of a series of angular rotation steps. This process of performing small rotations to obtain the total rotation is called the sequence of CORDIC micro rotations. The angular steps can be expressed as

<span id="page-36-4"></span>
$$
p_i = \frac{1}{\sqrt{1 + \tan(\phi_i)^2}} \cdot \begin{bmatrix} 1 & -\tan\phi_i \\ \tan\phi_i & 1 \end{bmatrix} \cdot p_{i-1}
$$
 (B.18)

This means that ideally, it holds that  $\sum_{i=0}^\infty \delta_i\cdot\phi_i=\theta$ , with  $\delta_i=\pm1.$  However, since an infinite sum is not feasible, an approximation has to be made. This can be represented as  $\sum_{i=0}^{N-1}\delta_i\cdot\phi_i\approx\theta.$  A further

reduction of the complexity of the calculations can be reached by restricting  $\tan\phi_i$  in Equation [B.18](#page-36-4) to values of  $\pm 2^{-i}$ . This means  $\phi_i$  can be written as in Equation [B.19](#page-37-0). The result can be seen in Equation [B.20.](#page-37-1)

<span id="page-37-0"></span>
$$
\phi_i = \tan^{-1}\left(\frac{1}{2^i}\right) \tag{B.19}
$$

<span id="page-37-1"></span>
$$
p_i = \frac{1}{\sqrt{1 + \delta_i \cdot 2^{-2i}}} \cdot \begin{bmatrix} 1 & -\delta_i \cdot 2^{-i} \\ \delta_i \cdot 2^{-i} & 1 \end{bmatrix} \cdot p_{i-1} = K_i \cdot \begin{bmatrix} 1 & -\delta_i \cdot 2^{-i} \\ \delta_i \cdot 2^{-i} & 1 \end{bmatrix} \cdot p_{i-1}
$$
 (B.20)

Replacing the tangent multiplication with a division by a power of 2 is an efficient method to reduce computation complexity. This due to the fact that the division can easily be implemented using a bit shift operation.

The only multiplication left in the algorithm is the multiplication with the scale factor  $K_i$ . This factor can be ignored during the process itself, and implemented afterwards. The multiplication of the  $K_i$  approach a constant value, which can be seen in Equation [B.21](#page-37-2)(for larger values of  $n$ ) [[12](#page-55-17)].

<span id="page-37-2"></span>
$$
\lim_{n \to \infty} K(n) = \prod_{i=0}^{n} K_i \approx 0.60725294104140
$$
 (B.21)

Intermediate micro rotations are represented with a new variable  $Z$ .

$$
Z_{i+1} = \theta - \sum_{i=0}^{N-1} \phi_i
$$
 (B.22)

In this equation, the total or given rotational angle is represented as  $\theta$ . For every small rotation of angle  $\phi_i$ , both Z and  $\delta_{i+1}$  need to be calculated. Variable  $\delta_{i+1}$  can be computed as

$$
\delta_{i+1} = \left\{ \begin{array}{ll} -1, & \text{for } Z_{i+1} < 0 \\ +1, & \text{for } Z_{i+1} \ge 0 \end{array} \right\} \tag{B.23}
$$

It is important to notice that the inverse tangent function which defines  $\phi_i$  (Equation [B.19](#page-37-0)) has a convergence region between  $\frac{-\pi}{2}$  and  $\frac{\pi}{2}$ . Therefore, order to be able to use the CORDIC algorithm for all angles some pre-rotations or quadrant corrections need to be set for the regions  $\frac{\pi}{2} < \theta < \pi$  and  $-\pi < \theta < -\frac{\pi}{2}$ .

Forthe first region, the relations  $\cos \theta + \frac{\pi}{2} = -\sin \theta$  and  $\sin \theta + \frac{\pi}{2} = \cos \theta$  is used [[12\]](#page-55-17). This results in the substitution of variables  $x \to y$ ,  $-y \to x$ ,  $\theta \to \theta - \frac{\pi}{2}$ .

Forthe second region, the relations  $\cos \theta - \frac{\pi}{2} = \sin \theta$  and  $\sin \theta - \frac{\pi}{2} = -\cos \theta$  is used [[12](#page-55-17)]. This results in the substitution of variables  $-x \to y$ ,  $y \to x$ ,  $\theta \to \theta + \frac{\pi}{2}$ .

# <span id="page-38-0"></span>Requirements for the entire system

# **Project requirements System requirements**

Table C.1: Requirements for the complete system



### **Sensor requirements**

Table C.2: Requirements for the design of the sensor.





# **Analyser requirements**

Table C.3: Requirements for the design of the analyser.



# **Reader requirements**

Table C.4: Requirements for the design of the analog reader.



# **Interface requirements Analyser-Reader Interface**



Table C.5: Requirements for the interface between the analyser and the reader

# <span id="page-40-0"></span>**Reader-Sensor Interface**

Table C.6: Requirements for the interface between the reader and the sensor.



 $\begin{bmatrix} 1 \\ 2 \end{bmatrix}$ 

# Sensor and readout circuit

# <span id="page-41-1"></span><span id="page-41-0"></span>**D.1. Circuit diagram**



# <span id="page-41-2"></span>**D.2. Inductor and capacitor values used for testing**



# Matlab Code

E

```
Listing E.1: Matlab script used to simulate the input signal for the analyser system.
1 %Matlab simulation for analyser part of BAP
2 %Mauries van Heteren (4712145) and Jonathan Dijkstra (4696778)
3 %Test input signal simulation code
4
5 function [filtered white noise, whitenoise, f in] = simulate reader (
      \leftrightarrow signal_number)
6 %time for sensor movement
7 \t\t\t 5 = 125e6;
      t_{max} = 10e-3;
9 %number of coupling factors for simulation
_{10} N k = 1e2 ;
11
12 % % % % create a white noise vector of 10 ms
13 [t, whitenoise] = create_white_noise(t_max);
14
15 %f axis
16 f axis = linspace (-fs /2, fs /2, length ( whitenoise ) );
17 % % % % % % % % meated output signal
18 [ filtered_white_noise, f in ] = create output signal ( whitenoise , t , N k,
          ↪ signal_number ) ;
19 end
20
_{21} function [filtered_white_noise, fres] = create_output_signal (whitenoise, t,
      \rightarrow N k, signal number)
22 % create the filtered white noise vector
23 bin size = length ( whitenoise ) / N k;
24 [L1, L2, C, R1, R2, freqs, omegas, k, fres ] = initiate reader parameters (N k,
          \leftrightarrow bin_size, signal_number);
25
26 k_temporal = 0.3;
27 frequency_response = calc_frequency_response (omegas , k_temporal ,C, L1 , L2
          \leftrightarrow, R1, R2);
28
_{29} fft whitenoise = fftshift (fft (whitenoise)):
30 fft_filtered_white_noise = fftshift(fft_whitenoise *abs(
           \leftrightarrow frequency response ) ) ;
31 filtered white noise = ifft (fft filtered white noise);
32
33 fs = 125e6;
_{34} f = linspace (-fs /2, fs /2, length (filtered white noise));
_{35} f small = linspace (25e6,29e6,10^4);
```

```
<sup>36</sup> frequency_small = calc_frequency_response(2*pi*f_small ,k_temporal ,C,L1
           \leftrightarrow, L2, R1, R2);
37 end
38
\frac{39}{20} function [t, whitenoise_trim] = create_white_noise(t_{max})
40 % Specifications of the test signal
41 fs = 125e6;
\begin{array}{lll} \text{42} & \text{t} & = \text{linspace}(0, \text{ t}\_\text{max}, \text{ fs} * \text{ t}\_\text{max}); \end{array}43 %create white noise
44 whitenoise_vect = ( randn ( size ( t ) ) )
*
0.01;
45 whitenoise_vect_long = [ whitenoise_vect whitenoise_vect
           \leftrightarrow whitenoise_vect];
\overline{AB}47 %trim the noise
48 offset = t_max*fs*0.4;
49 whitenoise_trim = whitenoise_vect_long(1 + offset:t_max*fs + offset);
50 end
51
52 function [L1, L2, C, R1, R2, freqs, omegas, k, fres] = initiate_reader_parameters (
      \rightarrow N k, bin size, signal number)
53 fs = 125e6;
t = 10e-3;
55 %inductor values
56 L1 = 0.6665e−6;
57 L2 = 0.6665e-6;
58
59 %capacitor value at 27.1MHz
60 Cs = 51.7489e-12;
61
62 %Change in 50Hz in this region can be approximated by
63 Delta_C = 0.2e−15;
64 C = Cs − ( signal_number −1)
*
5*
Delta_C ;
65
66 fres = 1/(2 * pi * sqrt(C * L1));67 %DC bias
68 R1 = 2;
69 %internal resistance of the inductor
70 R2 = 0.07;
71
72 %frequency axis
r_3 freqs = linspace (-fs /2, fs /2, fs *t);
74\% freqs = linspace (-fs /2, fs /2, bin size);
<sup>75</sup> omegas = freqs*2*pi;
76
\pi k = [linspace (0, 0.5, (N k/2)) linspace (0.5, 0, (N k/2))];
78 end
79
\omega function Z = calculate_impulse (w, k, C, L1, L2, R1, R2)
81 		 % calculate the impulse
82 Z = R1 + 1i * w * L1 + w^2 * k^2 * L1 * L2 * (1/(R2+1i * w * L2 + 1/(1i * w * C)));
83
84 end
85
\epsilon function Zs = calc frequency response (omegas, k, C, L1, L2, R1, R2)
87 % calculate the frequency response
88 Zs = [];
```

```
89 for p = 1: length (omegas)
\overline{z}s = [Zs calculate_impulse (omegas(p), k, C, L1, L2, R1, R2)];
91 end
92 end
```
Listing E.2: Matlab script used for testing the entire system.

```
%Matlab simulation for analyser part of BAP
2 %Mauries van Heteren (4712145) and Jonathan Dijkstra (4696778)
3 %Main code for testing system
4 resolution = 250;
5
6 %Simulate the system multiple times
\tau [f_axis1, x_in_divided_1, f_estimated1, f_in1] = estimate_frequency(1);
\frac{1}{8} [f_axis2, x_in_divided_2, f_estimated2, f_in2] = estimate_frequency (3);
9 [ f_axis3 , x_in_divided_3 , f_estimated3 , f_ in 3 ] = estimate_frequency ( 3 ) ;
10 [f_axis4, x_in_divided_4, f_estimated4, f_in4] = estimate_frequency(3);
11 [f_axis5, x_in_divided_5, f_estimated5, f_in5] = estimate_frequency(3);
12 [f_axis6, x_in_divided_6, f_estimated6, f_in6] = estimate_frequency(3);
13 [f_axis7, x_in-divided_7, f_estimated7, f_in7] = estimate frequency (3);14 [f_axis8, x_in-divided_8, f_estimated8, f_in8] = estimate_frequency(3);15 [f_axis9, x_in_divided_9, f_estimated9, f_in9] = estimate_frequency(3);
16 \left[ \int f axis10 , x in divided 10, f estimated10 , f in10 ] = estimate frequency (3);
17 [f\_axis11, x\_in\_divided\_11, f\_estimated11, f\_in11] = estimate_frequency (3);
18 [f_axis12, x_in_divided_12, f_estimated12, f_in12] = estimate_frequency (3);
19 [ f_axis13 , x_in_divided_13 , f_estimated13 , f_in13 ] = estimate_frequency ( 3 ) ;
_{20} [f axis14, x in divided 14, f estimated14, f in14] = estimate frequency (3);
_{21} [f axis15, x in divided 15, f estimated15, f in15] = estimate frequency (3);
_{22} [f_axis16, x_in_divided_16, f_estimated16, f_in16] = estimate_frequency(3);
23 [f_axis17, x_in_divided_17, f_estimated17, f_in17] = estimate_frequency (3);
_{24} [f_axis18, x_in_divided_18, f_estimated18, f_in18] = estimate_frequency(3);
25 [ f_axis19 , x_in_divided_19 , f_estimated19 , f_in19 ] = estimate_frequency ( 3 ) ;
26 [f_axis20, x_in_divided_20, f_estimated20, f_in20] = estimate_frequency(3);
_{27} [f_axis21, x_in_divided_21, f_estimated21, f_in21] = estimate_frequency (3);
_{28} [f axis22, x in divided 22, f estimated22 , f in22] = estimate frequency (3);
29 [f_axis23, x_in\_divided_23, f_estimated23, f_in23] = estimate_frequency(3);30 [ f_axis24 , x_in_divided_24 , f_estimated24 , f_in24 ] = estimate_frequency ( 3 ) ;
31 [f_axis25, x_in_divided_25, f_estimated25, f_in25] = estimate_frequency(3);<sup>32</sup> [f_axis26, x_in_divided_26, f_estimated26, f_in26] = estimate_frequency (3);
33 [ f_axis27 , x_in_divided_27 , f_estimated27 , f_in27 ] = estimate_frequency ( 3 ) ;
34 [f_axis28, x_in_divided_28, f_estimated28, f_in28] = estimate_frequency(3);
35 [ f_axis29 , x_in_divided_29 , f_estimated29 , f_in29 ] = estimate_frequency ( 3 ) ;
36 [ f_axis30 , x_in_divided_30 , f_estimated30 , f_in30 ] = estimate_frequency ( 3 ) ;
37 [f_axis31, x_in_divided_31, f_estimated31, f_in31] = estimate_frequency (3);
_38 [f axis32, x in divided 32, f estimated32, f in32] = estimate frequency (3);
_39 [f axis33, x in divided 33, f estimated33, f in33] = estimate frequency (3);
40 [ f_axis34 , x_in_divided_34 , f_estimated34 , f_in34 ] = estimate_frequency ( 3 ) ;
41 [ f_axis35 , x_in_divided_35 , f_estimated35 , f_in35 ] = estimate_frequency ( 3 ) ;
42 [ f_axis36 , x_in_divided_36 , f_estimated36 , f_in36 ] = estimate_frequency ( 3 ) ;
_{43} [f axis37, x in divided 37, f estimated37, f in37] = estimate frequency (3);
44 [f axis38, x in divided 38, f estimated38 , f in38] = estimate frequency (3);
45 [ f_axis39 , x_in_divided_39 , f_estimated39 , f_in39 ] = estimate_frequency ( 3 ) ;
46 [ f_axis40 , x_in_divided_40 , f_estimated40 , f_in40 ] = estimate_frequency ( 3 ) ;
47
48 f1_rounded = scale_f(f_in1, resolution);
49
50 f measured1 = [f estimated1 f estimated2 f estimated3 f estimated4
      \rightarrow f estimated5 f estimated6 f estimated7 f estimated8 f estimated9
      \rightarrow f estimated10 f estimated11 f estimated12 f estimated13
      ↪ f_estimated14 f_estimated15 f_estimated16 f_estimated17
      \rightarrow f estimated18 f estimated19 f estimated20];
_5 f measured2 = [festimated21 festimated22 festimated23 festimated24
```

```
43
```

```
\rightarrow f estimated25 f estimated26 f estimated27 f estimated28
      \rightarrow f estimated29 f estimated30 f estimated31 f estimated32
      \rightarrow f estimated33 f estimated34 f estimated35 f estimated36
      ↪ f_estimated37 f_estimated38 f_estimated39 f_estimated40 ] ;
52
\frac{1}{53} f measured = [f measured1 f measured2];
54
55 function scaled_f = scale_f(f_in, resolution)
56 n_steps = 0.5e6/resolution;
57 frequency scale = 26.9e6 : resolution : 27.4e6 – resolution;
58 for i = 1:n_steps
59 diff = abs (frequency_scale (i) - f_in );
\frac{1}{60} if ( diff < resolution /2)
61 scaled f = frequency scale (i);
62 end
63 end
64 end
65
66 function [f_axis, x_in_divided, f_estimated, f_in] = estimate_frequency (
      \leftrightarrow signal number)
67 t max = 10e−3; \%maximum time for the load cell over the reader
\epsilon<sub>68</sub> t fft = 10e−3; %maximum allowed time per measurement
69
70 %sample rate of the adc
71 fs = 125e6;
72
73 %Sample rate after downconversion
74 fs2 = 1e6;
75 %bandwidth of the signal
76 f_min = 26.9e6;
77 \quad \text{f} max = 27.4e6;
78 %parameter for the amount of noise in the signal
79 noise level = 0.05;
80
81 %bandwidth constraint by government law
s<sub>2</sub> B_max = f_max-f_min ;
83 %maximum achievable levels per measurement by the given bandwidth
\sum_{84}^{84} n_max = 2*B_max * t_fft;
85 %fft length at Nyquist given the bandwidth constraint
86 L = n_max;
87
88   WDefine input signal from reader to analyser (test signal from Jasper)
89 [x \in X, n, f \in I] = \text{simulate reader} (\text{signal number}) ;90
91 %ADC for input signal from reader
\mathfrak{so} adc_output = real(adc_block(x_in));
93 %ADC for noise input
\mathfrak{g}_4 adc_output_noise = adc_block(x_n);
95
96 %DDC for input signal from reader
97 ddc_output = ddc_block(adc_output, fs, f_min, f_max);
98 %DDC for noise input
99 ddc_output_noise = ddc_block (adc_output_noise, fs, f_min, f_max);
100
101 fs new = f s /125;
102 N = length (ddc output) ;
```

```
103 dF = fs_new/N;
104 f _axis = -fs_new /2:dF:fs_new/2-dF;
105
106 %FFT for input signal from reader
107 fft_output = fft_block(ddc_output);
108 %FFT for noise input
109 fft_output_noise = fft_block(ddc_output_noise);
110
111 %Divide to eliminate noise:
112 x_in_divided = fft_output./fft_output_noise;
113 %interpolation
114 f_estimated = spectrum_interpolation_block(x_in_divided,f_axis);
115
116 end
```
Listing E.3: Matlab script used to simulate the quantization of the ADC.

```
1 %Matlab simulation for analyser part of BAP
2 %Mauries van Heteren (4712145) and Jonathan Dijkstra (4696778)
3 %Quantization simulation code
4
\frac{1}{5} function adc output = adc block(x)
\epsilon N bits = 14; %ADC bits
7 \qquad A = \max(\text{real}(x));
\beta A = round (A \star 100)/100;
9 Range = [−A A];
10 x_digitised = adc_quantize(x, N_bits, Range);
11 adc_output = x_digitised;
12 end
13
14 function adc out = adc quantize (x, N bits , Range )
15 %This function quantizes the input signal
16 % Specifications analog to digital converter
17 %transpose if necessary
18 SZ = Size(X);_{19} if sz(1) > sz(2)
20 X = X'.21 end
_{22} q_lev = 2^A N_b bits;
23 %midPnt = q_lev/2; % center point
_{24} R max = Range (2);
25 R min = Range (1);
26 step = (R_{max} - R_{min})/q_{new};
27 offset = 0.5*step;
28 if (length (step) > 1 || step <= 0)
29 error ('Quantization range = [min_value, max_value], max_value >
            ↪ min_value ' )
30 end
31 % min max clamping
x \times ( \text{find } (x) = \text{Range}(2) ) = R \text{ max};33 \times ( \text{find } (x \leq \text{Range}(1))) = R_{\text{min}};34 % quantization
35 adc_out = ( round ( ( x−R_min ) . / step ) )
*
step ;
36 adc_out = adc_out + R_min;
37 adc_out ( find ( adc_out > R_max-off s et ) ) = R_max-step;
38 deltaR = diff (Range);
39 if deltaR > 040 x_min = Range(1) – deltaR/10;
41 x max = Range (2) + deltaR / 10;
42 else
43 error ('The upper limit must greater than the lower limit \ln')
44 end
45 end
```

```
Listing E.4: Matlab script used to simulate the DDC.
1 %Matlab simulation for analyser part of BAP
2 %Mauries van Heteren (4712145) and Jonathan Dijkstra (4696778)
3 %DDC simulation code
4
\frac{1}{5} function ddc output = ddc block (input, fs, f min, f max )
6
\frac{1}{7} bandwidth = f_max – f_min; % peak frequency range of signal
\sin s f_nco = f_min; % frequency of the oscillator
9
10 i [ mix_out_i , mix_out_q ] = mixer_block ( input , f_nco , fs ) ; % mix the signal
          \leftrightarrow with local oscillator
11
12 decimation factor = 125; %down sampling rate of the DDC
13 cic filter order = 15; %CIC filter order
14
15 cic output i = cic block (mix out i, decimation factor,
          \rightarrow cic filter order); %CIC filter the input i comp (choose
          \rightarrow cic block2 for matlab cic function)
16 cic output q = cic block (mix out q, decimation factor,
          \leftrightarrow cic filter order); %CIC filter the input q comp (choose
          \rightarrow cic block2 for matlab cic function)
17
       cic_output_comp1_i = cic_comp1_block ( cic_output_i, decimation_factor,
          \leftrightarrow cic filter order, fs); % compensation filters
19 cic_output_comp1_q = cic_comp1_block ( cic_output_q , decimation_factor ,
          \leftrightarrow cic_filter_order, fs); % compensation filters
20
_{21} ddc_output = complex(cic_output_q,cic_output_i); \%make a complex
          \leftrightarrow number from i and q comp
22
23
_{24} function [mix out i, mix out q] = mixer block (mix input, f nco, fs)
25 bits_angle_vector = 14;
26 iterations = 15;
z_7 step_size = 2*pi*f\_nco/fs;
28
29 %Calculate the angle input of the cordic algorithm phi[n]30 for i = 1:125031 theta(i) = i\aststep_size;
32
\lim_{x \to 0} \frac{1}{x} if theta(i) >= (2 * pi)\text{multiple} = \text{floor}(\text{theta}(\text{i})/(2 * \text{pi}));\text{theta (i)} = \text{theta (i)} - (\text{multiple} * 2 * \text{pi});36 end
37
38 theta(i) = fi(theta(i),1,bits_angle_vector);
39 end
40
41 %calculate the cordic output
\{y, x\} = cordicsincos (theta, iterations);
43
44 %Make the cordic output the proper length
45 needed length = length (mix input ) / length (x);
46 x = repmat(x,1, needed length);
47 \qquad \qquad y = \text{repmat}(y, 1, \text{needed length});
```

```
48
49 %Do the mixing operations
50 mix_out_i = mix_input .
*
x ;
\begin{array}{rcl} \textsf{mix\_out\_q = mix\_input.*y}; \end{array}52 end
53
54 function cic_output = cic_block2(CIC_in, decimation_factor,
         \leftrightarrow cic_filter_order)
55 CIC_in = [2eros(1,11000) CIC_in(11001:1239000) zeros(1,11000)];
56 R = decimation_factor; % decimation factor
57 K = cic_filter_order; %Order of filter / number of filter stages
58 cicDecim = dsp. CICDecimator (R, 1, K);
59 cic output = cicDecim ( CIC in ' ) ;
60 end
61
62
\epsilon<sup>8</sup> function cic output = cic block ( CIC in , decimation factor ,
         \leftrightarrow cic filter order)
64
65 R = decimation factor; %decimation f actor
66 K = cic_filter_order; %Order of filter / number of filter stages
67 B = [1, 2eros(1, R-1), -1]; %the numerator coefficients of the filter
\epsilon_{\text{68}} A = [R, -R]; %the denominator coefficients of the filter
69
\pi [h, t] = impz(B, A); % Impulse response of one stage
71 impulse response = h;
\frac{1}{72} if K > 1 \frac{1}{72} % calculate impulse response for K stages
73 for p=2:K74 impulse_response = conv(impulse_response, h);
75 end
76 end
77
78 B = impulse response; %put final coefficients in B
79 \quad A = 1\frac{1}{80} cic output = filter (B,A, CIC in ); %filter the input with the
             ↪ impulse response
81
82 end
83
84 function cic_comp1_output = cic_comp1_block (CIC_comp1_in,
         \rightarrow decimation factor, cic filter order, Fs)
85 R = decimation_factor; %decimation factor
\kappa = cic filter order; %Order of filter / number of filter stages
87
88 %Compensation f i l t e r according to ht t ps : / / ieeexplore . ieee . org /
             ↪ stamp / stamp . jsp ? tp=&arnumber=5349314
89 A_comp = 1; %the numerator coefficients of the filter
90 B_comp = [0 , zeros (1 ,R−1) , ( −1/16) , zeros (1 ,(2*
R−1)−(R+1) ) ,
             ↪ ( 9 / 8 ) , zeros (1 ,(3*
R−1)−(2*
R+1) ) , ( −1/16) ] ; %the denominator
             \leftrightarrow coefficients of the filter
0192 [h_comp, t_comp] = impz (B_comp, A_comp); % Impulse response of
             \leftrightarrow one stage
93 impulse response comp = h comp;
94 if K > 3
95 K = K - 1;
```

```
96 end
97 if K > 1 % calculate impulse response for K stages
             ↪ ( see paper )
98 for p=2:K99 impulse_response_comp = conv ( impulse_response_comp , h_comp
                    \leftrightarrow );
100 end
101 end
102 B = impulse_response_comp; \%put final coefficients in B
103 \t\t\t A = 1;104
105 cic_comp1_output = filter(B,A,CIC_comp1_in); %filter the input
             ↪ with the impulse response
106
107 %Low pass filter parameters
108 Fp = 0.63e6 ; % passband−edge frequency
109 Rp = 0.00057565; % Corresponds to 0.01 dB peak-to-peak ripple
110 Rst = 1e−9; % Corresponds to 180 dB stopband attenuation
111 Fst = 1.65e6; % Transition Width
112
_{113} h lp = firg r ( ' minorder ' , [0 , Fp / ( Fs / 2 ) , Fst / ( Fs / 2 ) , 1 ] , [ 1 1 0 0 ] , . . .
114 [Rp Rst]) ';%make the low pass filter with minimum order
115
116 z = zeros ( length ( impulse_response_comp )−length ( h_lp ) ,1) ; % zeros
h_{17} h_lp = [h_lp ; z] ;
118
h_l = impz(h_l, 1); % make impulse response of filter
120
121 cic_comp1_output = filter(h_lp,1,cic_comp1_output); %filter
             \leftrightarrow the input with the impulse response
122
123 cic_comp1_output = downsample ( cic_comp1_output , R) ; %downsample
             \leftrightarrow the filtered signal
124 end
125
126 end
```
Listing E.5: Matlab script used for testing the polynomial interpolation algorithm.

```
1 %Matlab simulation for analyser part of BAP
2 %Mauries van Heteren (4712145) and Jonathan Dijkstra (4696778)
3 %Spectrum interpolation algorithm
4
5 function [f estimated] = spectrum interpolation block (x, f)6 % Specification of the interpolation
7 [m, n] = size (x);
\frac{1}{8} percentage = 0.08;
9 search_size = 320;
10 resolution_polynomial = 10e7;
11 resolution = 250;
12 cutoff = 0.10;
13
14 %Filter unwanted high freq comp.
15 X = abs(X);
16 A = filter (x, cutoff);
17
18
19 % Moss Mind the frequency peak
20 [B,C]= find peak (A, search size, percentage);
21
22 %frequency domain of interest
23 f4 = f(B(1):B(end));
24
25 %frequency domain of interpolation
26 f precision = double (linspace (f4 (1), f4 (end), resolution polynomial) ;
27
28 % % % bolynomial interpolation on the data points
_{29} [p, ~, mu] = polyfit (f4, C, 12);
30 polynomial = polyval(p,f_precision,[],mu);
31
32 % % % % % % % % % % % Stimate the frequency of the interpolated polynomial
_{33} f interpolated = estimate frequency ( polynomial , f precision ) ;
34
35 %scale the frequency
_36 f estimated = scale f (f interpolated, resolution);
37
%calculate weighted average<br>
<sup>38</sup> % f weighted average = ca
39\% f weighted average = calc weighted average (C, f);
40 for i = 1: length (f(4))
f4(i) = f4(i) + 26.9e6;42 end
43 for i = 1: length (f precision)
44 f_precision(i) = f_precision(i) + 26.9e6;
45 end
      %plot of the frequency
47 p l o t ( f 4 , C ) ;
48 hold on;
49 plot (f_precision, polynomial);
50 hold off;
\frac{1}{51} title ('frequency response');
52 legend ('fft points', 'interpolated polynomial');
53 x label ('frequency [Hz]');
54 y label ('Amplitude');
55
```

```
56 end
57
58 function scaled f = scale f(f in , resolution)
59 % % Scale frequency range for interpolation
60 n steps = 0.5e6/ r e s o l u tion;
\epsilon<sub>61</sub> frequency_scale = 26.9e6 : resolution : 27.4e6 - resolution;
62 for i = 1:n_steps
\omega diff = abs (frequency_scale (i) - f_in );
\frac{64}{164} if ( diff \le resolution /2)
65 scaled f = frequency scale (i);
66 end
67 end
68 end
69
\pi function weighted_average = calc_weighted_average (input, f)
71 \% Weighted average code for peak detection for sine input of
              ↪ system
72 Average = 0;
73 S = sum(input);
74 for i = 1: length (input)
75 Average = Average + (C(i)/S) * B(i);
76 end
77 fixed part = fix (Average);
78 fractional part = Average - fix (Average);
\sigma_{\text{39}} weighted_average = f(fixed_part) + fractional_part \star(f(fixed_part +
              \leftrightarrow 1) -f (fixed part ) );
80
81 end
82
\frac{1}{83} function f_estimated = estimate_frequency (polynomial, f_axis)
84 % Mequency estimation by finding max value
85 f max = max(polynomial);
\epsilon_{\text{6}} festimated location = find ( polynomial == f max );
87 f estimated = f axis (f estimated location ) + 26.9e6;
88 end
89
\omega function [B,C]= find peak (A, search size, percentage)
91 \text{ M} = \text{max}(A);
92
93 %Search only in the neighbourhood of the peak
_{94} D = find (A == M);
95 A(1:D–search size) = 0;
96 A(D+search_size: end) = 0;
97 %Search only take values into account which are above the noise
              ightharpoonup floor
98 B = f i n d (A > 0) ;
99 C = A(B(1) : B(\text{end}));
100 end
101
102 function output = filter (A, cutoff)
103 % Unwanted peaks filter
104 B = A;
105 dA = diff (A) :
106 spike_level = 0.4*10^{13};
107 for i = 1: (length(dA) - 10)
108 dA = diff (B);
```

```
109 i f
( abs
(dA
( i ) ) > spike_level
)
110
               B(i+1) = (B(i) + B(i+2))/2;111
112 end
113 end
_{114} output = lowpass(B, cutoff);
115 end
```
# **Bibliography**

- <span id="page-55-8"></span><span id="page-55-1"></span>[1] Asad A Abidi. The path to the software-defined radio receiver. *IEEE Journal of solid-state circuits*, 42(5):954–966, 2007.
- <span id="page-55-2"></span>[2] Rik Bokhorst and Ruben van den Bos. Wireless passive weight sensor. Bachelor's thesis, TU Delft, Delft, The Netherlands, June 2020.
- <span id="page-55-7"></span>[3] Cagatay Candan. Fine resolution frequency estimation from three DFT samples: Case of windowed data. *Signal Processing*, 114(14):245–250, 2015.
- <span id="page-55-13"></span>[4] G Jovanovic Dolecek. Simple wideband CIC compensator. *Electronics Letters*, 45(24):1270–1272, 2009.
- <span id="page-55-9"></span>[5] Regeling gebruik van frequentieruimte zonder vergunning en zonder meldingsplicht 2015, December 2016. URL <http://wetten.overheid.nl/id/BWBR0036378/2016-12-28/0>.
- <span id="page-55-6"></span>[6] M Gasior and JL Gonzalez. Improving FFT frequency measurement resolution by parabolic and Gaussian spectrum interpolation. In *AIP Conference Proceedings*, volume 732, pages 276–285. American Institute of Physics, 2004.
- <span id="page-55-3"></span>[7] Jasper Insinger and Rogier Fischer. Weight sensor readout system. Bachelor's thesis, TU Delft, Delft, The Netherlands, June 2020.
- <span id="page-55-12"></span>[8] Sameer Kadam, Dhinesh Sasidaran, Amjad Awawdeh, Louis Johnson, and Michael Soderstrand. Comparison of various numerically controlled oscillators. In *The 2002 45th Midwest Symposium on Circuits and Systems, 2002. MWSCAS-2002.*, volume 3, pages III–III. IEEE, 2002.
- <span id="page-55-5"></span>[9] Walt Kester. Which ADC architecture is right for your application. In *EDA Tech Forum*, volume 2, pages 22–25, 2005.
- <span id="page-55-11"></span>[10] Walt Kester. Take the Mystery out of the infamous formula "SNR = 6.02N + 1.76dB,"and why you should care. *MT-001 Tutorial Devices*, 2009.
- <span id="page-55-0"></span>[11] L. Kleczewski and S.E. Haitjema. "A passive wireless load cell for in-situ productweight and position sensing on modular plastic conveyor belts". Bachelor project proposal for Eletrical Engineering, March 2020.
- <span id="page-55-17"></span>[12] Nagarjun Marappa. Design of Digital Down Converter Chain for Software Defined Radio Systems on FPGA. Master's Theses. 664., December 2015.
- <span id="page-55-4"></span>[13] David A Rauth and Vincent T Randal. Analog-to-digital conversion. part 5. *IEEE instrumentation & measurement magazine*, 8(4):44–54, 2005.
- <span id="page-55-14"></span>[14] RED PITAYA STEMLAB BOARD, 2020. URL [https://www.redpitaya.com/f130/](https://www.redpitaya.com/f130/STEMlab-board) [STEMlab-board](https://www.redpitaya.com/f130/STEMlab-board).
- <span id="page-55-15"></span>[15] Alex Tourigny-Plante, Vincent Michaud-Belleau, Nicolas Bourbeau Hébert, Hugo Bergeron, Jérôme Genest, and Jean-Daniel Deschênes. An open and flexible digital phase-locked loop for optical metrology. *Review of Scientific Instruments*, 89(9):093103, 2018.
- <span id="page-55-10"></span>[16] Papa-Silly Traore, Aktham Asfour, Jean-Paul Yonnet, and Christophe P Dolabdjian. Noise performance of SDR-based off-diagonal GMI sensors. *IEEE Sensors Journal*, 17(19):6175–6184, 2017.
- <span id="page-55-16"></span>[17] Jack Volder. The CORDIC computing technique. In *Papers presented at the the March 3-5, 1959, western joint computer conference*, pages 257–261, 1959.

<span id="page-56-0"></span>[18] Qingxiang Zhang and Xiaoxiao Su. The design of digital down converter based on FPGA. In *2012 8th International Conference on Wireless Communications, Networking and Mobile Computing*, pages 1–4. IEEE, 2012.