moerjielovecookie

Sawen_Blog

一个普通工科牲的博客网站
x
github
follow
email

2023 National Competition C Problem "Capacitance and Inductance Measurement Device" Design Report

Measurement Principle#

Refer to the solution on the website below

bookmark

Referring to the LCR tester, the basic working principle is to apply a sine excitation signal to the DUT, and then measure the voltage across the DUT and the current flowing through the DUT, from which the properties and parameters of the DUT can be calculated.

1720858696834.png

For an ideal capacitor, the current phase should lead the voltage across the capacitor by 90°. However, real capacitors have losses, which can be equivalent to a parallel combination of an ideal capacitor $C_p$ and an ideal resistor $R_p$. Therefore, the phase of the current leading the voltage will be less than 90°, and this phase difference is the loss angle.

2024after4202407131621163.png

Assuming the voltage across the DUT is $\dot{V}=V\cos(\omega t)$, the current flowing through the DUT is $\dot{I}=I \sin(\omega t - \varphi)$, the projection of the current on the imaginary axis is the current flowing through the ideal capacitor, and the projection on the real axis is the current flowing through the loss resistor.

Thus, the capacitive reactance of the parallel capacitor can be calculated as $X_{Cp}=\frac{V}{I \cos\varphi}$, and the capacitance value $C_P=\frac{1}{\omega X_{Cp}}=\frac{I \cos \varphi}{\omega V}$.

The value of the loss resistor is $R_p=\frac{V}{I \sin\varphi}$.

The ratio of the reactive power consumed by the component to the active power is defined as the Q value of the component, and the reciprocal of the Q value is the D value (tangent of the loss angle)

Q=RPXCp=cotφ,D=1Q=tanφQ=\frac{R_P}{X_{Cp}}=cot \varphi, D=\frac{1}{Q}=tan \varphi

The required parameters above can be obtained using orthogonal algorithms:

Isin(ωtφ)Vcos(ωt)=12VIsin(2ωtφ)12VIsinφIsin(ωtφ)Vsin(ωt)=12VIcos(2ωtφ)+12VIcosφ \begin{align}I\sin(\omega t-\varphi)\cdot V\cos(\omega t) & = \frac12VI\sin(2\omega t-\varphi)-\frac12VI\sin\varphi\\I\sin(\omega t-\varphi)\cdot V\sin(\omega t) & = -\frac12VI\cos(2\omega t-\varphi)+\frac12VI\cos\varphi \end{align}

After multiplying and passing through a low-pass filter, the DC components $-\frac{1}{2} VI \sin\varphi$ and $\frac{1}{2} VI \cos\varphi$ can be obtained, allowing for the calculation of the required tangent of the loss angle

tanφ=VIsinφVIcosφtan\varphi = \frac{VI \sin \varphi}{VI \cos \varphi}

Additionally, the following parameters can be obtained

The capacitive reactance of the ideal capacitor in parallel Xcp=VIcosφ=V2VIcosφ, capacitance is Cp=1ωXcp, the parallel loss resistor Rp=VIsinφ=V2VIsinφ. Where V2 can be obtained by squaring the voltage and filtering out high-frequency components.\text{The capacitive reactance of the ideal capacitor in parallel }X_{cp}=\frac V{I\cos\varphi}=\frac{V^2}{VI\cos\varphi} \text{, capacitance is }C_p=\frac1{\omega X_{cp}},\text{ the parallel loss resistor }\\R_{p}=\frac V{I\sin\varphi}=\frac{V^2}{VI\sin\varphi}\text{. Where }V^2\text{ can be obtained by squaring the voltage and filtering out high-frequency components.}

Parameter Simulation#

The existing ADC input voltage range is 0~2V, with an input bias of 1V; the DAC output voltage range is 1V peak-to-peak, and bias can also be added,

1721052590800.png

The capacitance value is 1nF-100nF, and when the shunt resistor is 0.33Ω, the output voltage peak-to-peak value is 4-200mv. When measuring inductance at a frequency of 1MHz, with an inductance value of 10uF-100uF, the output voltage peak-to-peak value is 15-150mv. Since the ADC module's input range is 0~2V, the signal is amplified by 9 times, with the peak-to-peak value amplified to about 1.8V.

Debugging Records#

The signal output from the DAC does not match the impedance of the LC filter, resulting in a low amplitude of the signal at the input of the LC filter.

After powering on the detection circuit for the DUT, there is a -500mv bias at the input.

The LC filter is designed as follows; when the DAC outputs a 1MHz signal, the higher harmonics are quite severe, so a low-pass LC filter with a passband of 1.2MHz is designed to filter out high-frequency noise.

1721448168186.png

1721448231710.png

PCB Design#

First Generation#

R8 is used to connect the test fixture, with the excitation signal input from P1, passing through the capacitor or inductor under test on R8, and the current flowing into the subsequent current detection circuit through C5,

2024after4202407211655761.svg

1721560509597.png

With this design, the input impedance of the circuit is the impedance value of the DUT at a specific frequency, while the output impedance of the front amplifier is 50Ω, which will cause the amplitude of the input signal to not be the expected value.

Improvement#

Remove the 50Ω resistor used for impedance matching at the output of the front amplifier, utilizing the low output impedance characteristic of the operational amplifier, ensuring that all the output signal voltage is applied to the input of the above circuit.

The reason for this improvement is that the output of the operational amplifier does not drive capacitive loads, and with the LC filter and long coaxial cable, there is no need to connect a matching resistor at the output.

FPGA Program Design#

According to the principles above, two ADCs are needed to collect current and voltage signals, and one DAC to generate the excitation signal. Therefore, the DE0nano is chosen, which has two extended 40-pin headers that can connect to two ADDA modules.

2024after4202407231614021.bmp

The FPGA's crystal oscillator frequency is 50MHz, and through PLL division, 20MHz and 80MHz are generated, where the ADC clock is 20M and the DAC clock is 80M. These are then connected to ADC_Interface and DAC_Interface respectively.

The signal width collected by the ADC is 10 bits, discarding the lowest two bits for subsequent signal processing, while pausing for 0.5 seconds after collecting 1024 samples before proceeding to the next collection.

The DAC section uses an NCO to generate a sine wave signal, switching frequency words via a dip switch, outputting to DAC_interface, left-shifting by 1 bit before outputting, and then amplifying by 2 times through a non-inverting amplifier to enhance the signal driving capability.

The current and voltage data collected by the ADC is stored in RAM, and phase shifting is achieved by changing the starting address for reading. The ADC's sampling rate is 20M, and when collecting 100K signals, 200 points are collected per cycle. Therefore, to achieve a phase shift of $\frac{\pi}{2}$, it is only necessary to start reading data from 50 in RAM, and the read signal will be the signal read from RAM starting from 0, phase-shifted by $\frac{\pi}{2}$.

The data collected by the ADC is unsigned, and performing multiplication filtering will not match the calculation results. Therefore, an additional module for converting unsigned to signed numbers is added, converting to signed numbers before multiplication, and then sending it to the low-pass filter to obtain the required values. The output of the low-pass filter is truncated, keeping only the high 16 bits of the data to reduce the impact of jitter on the DC signal results.

Measurement Results#

1721657082949.png

The output of the first Lowpass is $VI\cos\phi$, the output of the second Lowpass is $\frac{1}{2}VI\cos \varphi$, and the output of the third Lowpass is $V^2$. The calculation process for the capacitive reactance is as follows:

Based on the fitting relationship between the simulated input current and output voltage, it can be concluded that the amplitude of the output voltage collected equals the current ÷ 0.305, thus the capacitive reactance is the third output ÷ 2 ÷ the first output ÷ 0.305.

Circuit Display#

2024after4202407231606426.jpg

Future Plans#

Add SPI communication to transmit the sampled and calculated data to the TI development board for further computation and display.

Loading...
Ownership of this post data is guaranteed by blockchain and smart contracts to the creator alone.