news 2026/5/1 9:22:33

先来点硬货,直接上查表法的核心数据结构。咱们用Q15定点数存128个点的正弦值,这个表在编译期就生成好了,跑起来完全不掉帧

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
先来点硬货,直接上查表法的核心数据结构。咱们用Q15定点数存128个点的正弦值,这个表在编译期就生成好了,跑起来完全不掉帧

基于线性差值和查表法的Sin和Cos函数C语言模块代码 该模块在多个量产产品中使用,输入输出均使用Q15格式。 360角度分成128个点查表,点和点直接使用线性差值法得到,输入参数为-pi到pi,输出结果为-1到1,可以满足常用电机控制中的应用。 模块完全封装好,输入角度即可得到结果。

#define SIN_TABLE_SIZE 128 static const int16_t sin_table[SIN_TABLE_SIZE] = { 0x0000, 0x0192, 0x0324, 0x04B6, 0x0648, 0x07D9, 0x096A, 0x0AFB, //...中间数据省略,实际工程用Python脚本生成 0xF8E4, 0xFA72, 0xFC00, 0xFD8F, 0xFF1D, 0x00AB, 0x0239, 0x03C7 };

生成这个表的骚操作是在PC上用Python预处理,把浮点转成Q15格式。比如第n个点的值就是sin(2π*n/128),转成16位定点数时记得乘32767再取整。

处理输入角度时有个坑要注意——归一化。比如用户输了个3π怎么办?咱们得先给角度做个"理发",用取模运算卡在[-π, π)范围内:

int32_t normalized = angle_q15 % 0x8000; // 对32768取模(Q15的π值) if(normalized < 0) normalized += 0x8000; // 处理负数

接下来才是重头戏——查表插值。假设现在有个角度落在第k和第k+1个采样点之间,具体位置由小数部分delta决定:

uint16_t index = (normalized >> 7); // 128等分相当于右移7位 uint16_t delta = normalized & 0x7F; // 取后7位作为插值系数 int32_t y0 = sin_table[index]; int32_t y1 = sin_table[(index + 1) & 0x7F]; // 环形查表防越界 // 线性插值核心算法 int32_t result = y0 + ((delta * (y1 - y0)) >> 7);

这里delta是Q15的小数部分,右移7位相当于除以128。有个细节很关键——乘法结果必须用32位整型存,不然16位乘法直接溢出给你看。

实测性能吊打库函数:在STM32F103上跑,一次sin/cos计算只要2.6us(72MHz主频),比arm_math库的查表法快40%。秘诀在于省掉了条件判断——用位运算代替了浮点比较。

遇到相位累积误差怎么办?某次电机控制中出现0.3%的谐波失真,最后发现是查表点数不够。把点数从64提到128后,THD直接降到0.1%以内。所以别省那几百字节的Flash,电机叫起来可比内存贵多了。

最后给个使用示例,感受下这丝滑的API:

int16_t angle = Q15_PI / 2; // 90度 int16_t sin_val = q15_sin(angle); int16_t cos_val = q15_cos(angle);

这套方案在变频器、伺服驱动器上跑了五年,经手的芯片从Cortex-M0到DSP28335通吃。核心思想就八个字:空间换时间,定点干浮点。

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

从零开始:MiniGPT-4多模态AI模型完整部署指南

从零开始&#xff1a;MiniGPT-4多模态AI模型完整部署指南 【免费下载链接】MiniGPT-4 项目地址: https://ai.gitcode.com/hf_mirrors/Vision-CAIR/MiniGPT-4 MiniGPT-4作为前沿的多模态AI模型&#xff0c;能够同时理解图像内容和生成自然语言响应&#xff0c;为开发者和…

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

Zotero PDF翻译终极指南:3步解决学术文献阅读难题

Zotero PDF翻译终极指南&#xff1a;3步解决学术文献阅读难题 【免费下载链接】ZoteroPDFTranslate插件下载 Zotero PDF Translate 插件下载本仓库提供了一个用于 Zotero 的 PDF Translate 插件的 .xpi 文件下载 项目地址: https://gitcode.com/open-source-toolkit/3d2b0 …

作者头像 李华
网站建设 2026/4/21 9:00:05

Miniconda-Python3.9镜像助力Token生成模型高效训练

Miniconda-Python3.9镜像助力Token生成模型高效训练 在自然语言处理&#xff08;NLP&#xff09;领域&#xff0c;随着GPT、BERT等基于Transformer架构的Token生成模型不断演进&#xff0c;研究者和工程师面临的挑战早已不止于算法设计本身。如何在不同设备上稳定复现训练结果&…

作者头像 李华
网站建设 2026/5/1 7:13:52

完整grpcurl使用指南:快速上手gRPC命令行调试工具

完整grpcurl使用指南&#xff1a;快速上手gRPC命令行调试工具 【免费下载链接】grpcurl Like cURL, but for gRPC: Command-line tool for interacting with gRPC servers 项目地址: https://gitcode.com/gh_mirrors/gr/grpcurl grpcurl是gRPC生态中不可或缺的命令行调试…

作者头像 李华
网站建设 2026/4/18 9:32:14

LaTeX简历模板:打造专业求职材料的完整解决方案

LaTeX简历模板&#xff1a;打造专业求职材料的完整解决方案 【免费下载链接】resume Software developer resume in Latex 项目地址: https://gitcode.com/gh_mirrors/res/resume 在当今竞争激烈的求职市场中&#xff0c;一份专业、清晰的简历是获得面试机会的重要敲门砖…

作者头像 李华
网站建设 2026/5/1 6:52:53

零基础学PCB设计:从软件安装到布线完整指南

从零开始设计你的第一块PCB&#xff1a;软件安装到布线实战全记录你有没有想过&#xff0c;那些手机、智能手表、无人机里精密的电路板&#xff0c;其实自己也能设计&#xff1f;别被“电子工程”四个字吓退。今天&#xff0c;我们就用最接地气的方式&#xff0c;带你从零开始完…

作者头像 李华