Measurement Principles#
Refer to the solution on the website below
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.
For an ideal capacitor, the current phase should lead the voltage across the capacitor by 90°. However, real capacitors have losses, which can be equivalently represented as 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.
Assuming the voltage across the DUT is $\dot{V}=V\cos(\omega t)$, and 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, while 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)
The required parameters above can be obtained using the orthogonal algorithm:
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
Additionally, the following parameters can be calculated
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,
The capacitance value ranges from 1nF to 100nF, and when the shunt resistor is 0.33Ω, the output voltage peak-to-peak is 4-200mv. When measuring inductance at a frequency of 1MHz, with inductance values ranging from 10uF to 100uF, the output voltage peak-to-peak is 15-150mv. Since the ADC module's input range is 0~2V, the signal is amplified 9 times, bringing the peak-to-peak value to around 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.
PCB Design#
Initial Version#
R8 is used to connect to the test fixture, with the excitation signal input from P1, passing through the capacitor or inductor under test on R8, and the current flows into the subsequent current detection circuit through C5,
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-end amplifier is 50Ω, which causes the amplitude of the input signal to not be as expected.
Improvement#
The 50Ω resistor used for impedance matching at the output of the front-end amplifier is removed, utilizing the low output impedance characteristic of the operational amplifier, ensuring that all output signal voltage is applied to the input of the above circuit.
The reason for this improvement is that the operational amplifier's subsequent stage does not carry 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#
Based on 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.
The FPGA's crystal oscillator frequency is 50MHz, and through PLL division, 20MHz and 80MHz are generated, with the ADC clock at 20M and the DAC clock at 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. After collecting 1024 samples, a pause of 0.5 seconds is made before the next collection.
The DAC section uses an NCO to generate a sine wave signal, switching the frequency word via a dip switch, outputting to DAC_interface, left-shifting by 1 bit, and then amplifying by a non-inverting amplifier by a factor of 2 to enhance the signal's driving capability.
The current and voltage data collected by the ADC are 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}$, data reading from RAM starts at 50, and the read signal is the signal read from RAM starting at 0, phase-shifted by $\frac{\pi}{2}$.
The data collected by the ADC is unsigned, and performing multiplication filtering would not match the calculation results. Therefore, an additional module is added to convert unsigned to signed numbers, and after conversion to signed numbers, multiplication is performed, followed by passing through a low-pass filter to obtain the required values. The output of the low-pass filter is truncated, keeping only the highest 16 bits of data to reduce the impact of jitter in the DC signal on the results.
Measurement Results#
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 derived that the amplitude of the collected output voltage equals the current ÷ 0.305, thus the capacitive reactance is the third output ÷ 2 ÷ the first output ÷ 0.305.
Circuit Display#
Follow-up Plan#
Add SPI communication to transmit the sampled and calculated data to the TI development board for further calculation and display.