前言
在微弱信号检测、LCR电桥设计、以及电赛仪器仪表类题目中,锁相放大器 (Lock-in Amplifier)是核心中的核心。传统的模拟方案(如 AD630、AD8302)存在外围电路复杂、零点漂移大、受温漂影响严重、且无法精确测量全角度相位等问题。
本文介绍一种基于STM32F407 + FPU实现的全数字双通道锁相放大器方案。该方案摒弃了传统的IIR高通滤波器去直流(会导致严重的相位偏差),采用协方差数学修正算法,实现了物理意义上的零相移,实测相位差测量精度达到0.04°级别。
一、 核心痛点与解决方案
在数字锁相放大器的实现中,通常会遇到三大拦路虎:
DDS 信号不纯:普通的查表法输出的是阶梯波,信噪比低。
本方案:采用32位相位累加器 + CCM RAM 查表 + 线性插值算法,SFDR > 90dB。
去直流导致的相移:为了去除硬件ADC的直流偏置,通常使用 val = val - dc_filter(val)。本质是高通滤波,会导致信号在经过算法时产生相移(尤其是低频信号)。
本方案:使用基于统计学的协方差修正算法。利用单次数据块的统计特性,在数学层面上直接扣除直流分量。相位偏移恒定为 0.00°。
双通道不同步:测量阻抗需要电压/电流两路信号,如果板间时钟不同步,相位会漂移。
本方案:采用 STM32 双重 ADC (Dual Mode) + DMA 乒乓缓存 +相位快照同步机制,实现两路信号的皮秒级对齐。
二、 算法原理验证
在编写 C 代码前,我搭建了完整的 MATLAB 仿真环境,模拟了真实 MCU 的 ADC 量化误差、白噪声干扰和定点化计算。
可以看到,利用改进后的算法,相位收敛过程爬升期极短,上电即稳定,且最终相位死死咬合在目标值,没有任何系统性偏差。
三、 硬件实测数据 (STM32F407)
测试环境:
MCU: STM32F407ZGT6
信号源: 10kHz 正弦波,AM 调制噪声
ADC: 80k ~ 100k Sampling Rate (Timer 触发)
1. 双通道相位差测量(验证 LCR 电桥核心功能)
信号源 CH1 输出 3°,CH2 输出 46°,理论相位差43°。
结果分析:实测读数为 -35.9936 ~ -36.2149左右波动,精度达到0.02°级别,完全满足电赛要求。
2. 强噪声环境测试(验证微弱信号提取)
给信号施加120% 深度的 AM 噪声调制,信号在示波器上已经看成了“毛刺”。
结果分析:尽管原始信号幅度剧烈抖动,锁相算法依然能从噪声中提取出核心频率的相位信息,相位差读数依然稳定。
四、 代码架构优势
本项目并非简单的 while(1) 循环,有详细的代码架构:
运算性能:核心算法经过汇编级优化,利用 Cortex-M4 DSP 指令集,单次 512 点解调仅需几十微秒,CPU 占用率< 5%。
OOP 封装:采用结构体封装对象 DLIA_Handle_t,支持无限开启多通道。
双缓冲机制:DMA Ping-Pong Buffer 设计,采样与计算并行,数据无丢失。
五、 总结与资源获取
这是一套经过实战验证的、可直接用于产品的源码方案。如果你正在做电赛仪器类题目、光电检测、或者阻抗分析仪,这套代码可以直接作为你的核心数据处理引擎。
目前源码提供的内容包括:
STM32F407 Keil 完整工程 (含 Dual ADC/DMA/DSP 配置)
Lockin_Amplifier 核心算法库
MATLAB 完整仿真验证脚本 (方便你修改参数)
算法技术文档 (PDF)
有需要源码的同学请私信联系