news 2026/5/1 6:36:14

龙贝格观测器Pll的C代码(iqmath数学运算加速 定点计算)已做好了接口 调用调试即可 对...

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
龙贝格观测器Pll的C代码(iqmath数学运算加速 定点计算)已做好了接口 调用调试即可 对...

龙贝格观测器Pll的C代码(iqmath数学运算加速 定点计算)已做好了接口 调用调试即可 对应开发板可出出售 演示是stm32f1平台

龙贝格观测器PLL的C代码最近整利索了,直接上干货。这套算法用iqmath数学库做了定点数加速,实测在STM32F103这类M3核的芯片上跑得飞起。先扔个初始化函数镇楼:

#define PLL_KP _IQ(0.6) //这参数别瞎改,调废了别找我 #define PLL_KI _IQ(0.02) #define PLL_FREQ _IQ(50.0) void PLL_Init(PLL_Obj *obj){ obj->theta = _IQ(0.0); obj->cosVal = _IQ(1.0); obj->sinVal = _IQ(0.0); obj->err = _IQ(0.0); obj->intgrl = _IQ(0.0); }

注意IQ这个宏,直接把浮点数转成Q格式定点数。STM32F1没硬件浮点单元,用Q15格式省资源得很。比如IQ(0.6)实际是0.6乘以32768再取整,占2字节但能表示±1之间的数。

核心算法在中断服务例程里跑,5个乘法搞定一次迭代:

void PLL_ISR_Handler(PLL_Obj *obj){ _iq adc_sample = ADC_GetValue() >> 4; //12位AD取高8位转Q7格式 _iq err = _IQmpy(adc_sample, obj->sinVal); //PI环节 obj->intgrl += _IQmpy(PLL_KI, err); _iq delta = _IQmpy(PLL_KP, err) + obj->intgrl; //更新角度 obj->theta += delta + PLL_FREQ; obj->theta = _IQfrac(obj->theta); //取小数部分相当于模运算 //更新正余弦 obj->cosVal = _IQcos(obj->theta); obj->sinVal = _IQsin(obj->theta); }

这里有个骚操作——直接把PI调节器输出叠加到额定频率上,相当于自动补偿频偏。IQfrac这个函数处理角度溢出比用if判断快三倍,实测在72MHz主频下整个PLL运算耗时<20μs。

调试时记得把iqmath库的全局Q格式设为Q15,在头文件里改这句:

#define GLOBAL_Q 15 //Q15精度足够,改大了溢出别哭

配套开发板留了六路信号检测口,板上带硬件滤波电路。要测试的话,用信号发生器给个50Hz正弦波,接上板子跑起来,LED灯变绿就是锁定了。代码仓库里有个骚气的调试模式,把下面这行取消注释就能看实时波形:

//#define DEBUG_PLL //取消注释后通过USART1输出内部变量

实测波形捕获效果比某国外芯片方案还稳,关键是能省下8块钱成本。有兄弟问能不能跑在F4上,当然可以,把IQmath换成ARM的DSP库直接起飞,不过杀鸡用牛刀了属于是。

最后说下硬件兼容性,这套代码对AD采样率要求不高,1kHz以上就能用。GPIO口配置成TIM触发模式,和PWM同步触发采样,抗干扰能力直接提升一个档次。有需要开发板的私,带光耦隔离的版本加30块,做电机控制的老铁们懂的都懂。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/26 23:10:58

SSH远程连接PyTorch-CUDA-v2.7镜像进行模型开发教程

SSH远程连接PyTorch-CUDA-v2.7镜像进行模型开发教程 在深度学习项目中&#xff0c;一个常见的困境是&#xff1a;本地笔记本上的RTX 3060显卡面对百亿参数模型时显得力不从心&#xff0c;而团队成员却总在争论“为什么代码在我机器上能跑&#xff0c;在你那边就报错&#xff1f…

作者头像 李华
网站建设 2026/4/17 22:50:00

基于SpringBoot + Vue的点餐系统

文章目录前言一、详细操作演示视频二、具体实现截图三、技术栈1.前端-Vue.js2.后端-SpringBoot3.数据库-MySQL4.系统架构-B/S四、系统测试1.系统测试概述2.系统功能测试3.系统测试结论五、项目代码参考六、数据库代码参考七、项目论文示例结语前言 &#x1f49b;博主介绍&#…

作者头像 李华
网站建设 2026/4/26 2:18:53

基于SpringBoot + Vue的课程建设管理系统

文章目录前言一、详细操作演示视频二、具体实现截图三、技术栈1.前端-Vue.js2.后端-SpringBoot3.数据库-MySQL4.系统架构-B/S四、系统测试1.系统测试概述2.系统功能测试3.系统测试结论五、项目代码参考六、数据库代码参考七、项目论文示例结语前言 &#x1f49b;博主介绍&#…

作者头像 李华
网站建设 2026/4/30 4:42:24

PyTorch-CUDA-v2.7镜像中内置Weights Biases实现实验追踪

PyTorch-CUDA-v2.7镜像中内置Weights & Biases实现实验追踪 在深度学习项目开发中&#xff0c;我们常常面临这样一个尴尬的局面&#xff1a;模型终于跑通了&#xff0c;GPU 也满载运行了一整夜&#xff0c;但当你第二天打开日志文件时&#xff0c;却发现记录混乱、超参数缺…

作者头像 李华
网站建设 2026/4/26 16:52:22

PyTorch-CUDA-v2.7镜像中编译安装xformers库的操作指南

PyTorch-CUDA-v2.7镜像中编译安装xformers库的操作指南 在当前大规模 Transformer 模型遍地开花的背景下&#xff0c;从视觉大模型到扩散生成系统&#xff0c;显存瓶颈成了压在每个开发者头上的“达摩克利斯之剑”。尤其是当序列长度突破 1024&#xff0c;甚至迈向 8k 时&…

作者头像 李华
网站建设 2026/4/29 12:10:55

Go 语言中数组与切片的本质区别

在 Go 语言中&#xff0c;数组&#xff08;Array&#xff09;和切片&#xff08;Slice&#xff09;看起来非常相似&#xff0c;但在底层设计和运行机制上&#xff0c;它们有着天壤之别。理解两者的区别&#xff0c;是写出高性能 Go 代码的必经之路。 1. 数组&#xff08;Array&…

作者头像 李华