STM32 使用IQmath实现SVPWM
IQMATH
TI
的片子很香,做的也很好,但是成本相对ST会更高,电机控制方面,TI
无疑是做的最好的方案之一,另外TI
针对没有浮点运算器的定点DSP
推出了IQMATH
库,在使用Q格式对数据进行分析和处理的过程中,十分方便,代码也变得更加简洁,本文将使用TI
的方案实现SVPWM
,在这里感谢TI
。
测试平台参数:
硬件:stm32f103
软件:标准外设库3.5
IDE:MDK-ARM
添加IQmathLib到工程中
将IQmathlib
解压可以得到如下文件,其中包含各个平台下的静态库,本文使用STM32F1
在keil
环境下进行开发,需要使用的是rvmdk-cm3
。
打开一个keil
工程,在菜单界面点击如下图所示的图标进入project items
;
添加IQmath
组,并添加rvmdk-cm3
路径下的静态库,和头文件;
点击下图所示的图标进入工程熟悉的设置;
添加rvmdk-cm3
静态库的路径,和头文件的包含路径,如下图所示;
最终,build
整个工程即可。
测试部分程序
/**
******************************************************************************
* @file Project/STM32F10x_StdPeriph_Template/main.c
* @author MCD Application Team
* @version V3.5.0
* @date 08-April-2011
* @brief Main program body
******************************************************************************
* @attention
*
* THE PRESENT FIRMWARE WHICH IS FOR GUIDANCE ONLY AIMS AT PROVIDING CUSTOMERS
* WITH CODING INFORMATION REGARDING THEIR PRODUCTS IN ORDER FOR THEM TO SAVE
* TIME. AS A RESULT, STMICROELECTRONICS SHALL NOT BE HELD LIABLE FOR ANY
* DIRECT, INDIRECT OR CONSEQUENTIAL DAMAGES WITH RESPECT TO ANY CLAIMS ARISING
* FROM THE CONTENT OF SUCH FIRMWARE AND/OR THE USE MADE BY CUSTOMERS OF THE
* CODING INFORMATION CONTAINED HEREIN IN CONNECTION WITH THEIR PRODUCTS.
*
* <h2><center>© COPYRIGHT 2011 STMicroelectronics</center></h2>
******************************************************************************
*/
/* Includes ------------------------------------------------------------------*/
#include "stm32f10x.h"
#include <stdio.h>
#include <stdint.h>
#include "serial_scope.h"
#include "common.h"
#include "IQmathLib.h"
#include "usart_driver.h"
#include "clarke.h"
#include "park.h"
#include "svpwm.h"
/**
* @brief Main program.
* @param None
* @retval None
*/
sv_mod_t svpwm = SVGEN_DEFAULTS;
#define CLARK 0
#define PARK 1
#define SVPWM 2
#define SVPWM_REG 3
int main(void)
{
int user_data[4] = { 0 };
static int16_t time_cnt = 0;
Trig_Components a;
Trig_Components b;
_iq final_angle;
usart_init();
while (1)
{
time_cnt-=32;
clarke_parameter.As = _IQsinPU(time_cnt);
clarke_parameter.Bs = _IQsinPU(time_cnt-0x5555);
if(clarke_parameter.As > 32767){
clarke_parameter.As = 32767;
}
if(clarke_parameter.As < -32768){
clarke_parameter.As = -32768;
}
if(clarke_parameter.Bs > 32767){
clarke_parameter.Bs = 32767;
}
if(clarke_parameter.Bs < -32768){
clarke_parameter.Bs = -32768;
}
clarke_calc(&clarke_parameter);
park_parameter.Alpha = clarke_parameter.Alpha;
park_parameter.Beta = clarke_parameter.Beta;
park_parameter.Sin = trig_functions(time_cnt).hsin;
park_parameter.Cos = trig_functions(time_cnt).hcos;
park_parameter.Angle = -time_cnt;
park_calc(&park_parameter);
svpwm.Ualpha = clarke_parameter.Alpha;
svpwm.Ubeta = clarke_parameter.Beta;
svpwm_calc(&svpwm);
#define FOC_DEBUG SVPWM_REG
#if (FOC_DEBUG == CLEAK)
user_data[0] = clarke_parameter.As;
user_data[1] = clarke_parameter.Bs;
user_data[2] = clarke_parameter.Alpha;
user_data[3] = clarke_parameter.Beta;
#elif (FOC_DEBUG == PARK)
user_data[0] = clarke_parameter.As;
user_data[1] = clarke_parameter.Bs;
user_data[2] = park_parameter.Ds;
user_data[3] = park_parameter.Qs;
#elif (FOC_DEBUG == SVPWM)
user_data[0] = (uint16_t)svpwm.Ta;
user_data[1] = (uint16_t)svpwm.Tb;
user_data[2] = (uint16_t)svpwm.Tc;
user_data[3] = svpwm.VecSector*5000;
#elif (FOC_DEBUG == SVPWM_REG)
//换算的CCRx寄存器的值
sv_regs_mod_t sv_regs = svpwm_get_regs_mod(7200,&svpwm);
user_data[0] = sv_regs.ccr1;
user_data[1] = sv_regs.ccr2;
user_data[2] = sv_regs.ccr3;
user_data[3] = svpwm.VecSector*1000;
#endif
SDS_OutPut_Data_INT(user_data);
}
return 0;
}
/**
* @}
*/
/******************* (C) COPYRIGHT 2011 STMicroelectronics *****END OF FILE****/
STM32 使用IQmath实现SVPWM的更多相关文章
- 【STM32系列汇总】小白博主的STM32实战快速进阶之路(持续更新)
我把之前在学习和工作中使用STM32进行嵌入式开发的经验和教程等相关整理到这里,方便查阅学习,如果能帮助到您,请帮忙点个赞: 本文的宗旨 STM32 只是一个硬件平台,同样地他可以换成MSP430,N ...
- FOC中的Clarke变换和Park变换详解(动图+推导+仿真+附件代码)
文章目录 1 前言 2 自然坐标系ABC 3 αβ\alpha\betaαβ 坐标系 3.1 Clarke变换 3.2 Clarke反变换 4 dqdqdq 坐标系 4.1 Park变换 正转 反转 ...
- 基于stm32f427实现SVPWM控制永磁同步开环转动
1.SVPWM原理简介 PWM(Pulse Width Modulation)脉宽调整,这是一种利用面积等效原理实现的控制技术.SVPWM(Space Vector PWM)空间矢量PWM控制,因为控 ...
- stm32定时器时钟以及中间对齐模式
在永磁同步电机的控制中,需要对电机的三相定子施加一定的电压,才能控制电机转动.现在用的较多的是SVPWM(SVPWM的具体原理会在后面另写一篇博客说明),要想产生SVPWM波形,需要控制的三相电压呈如 ...
- BLDC有感FOC算法理论及其STM32软硬件实现
位置传感器:旋转编码器 MCU:STM32F405RGT6 功率MOS驱动芯片:DRV8301 全文均假设在无弱磁控制的情况下 FOC算法理论 首先,我们要知道FO ...
- ucos实时操作系统学习笔记——操作系统在STM32的移植
使用ucos实时操作系统是在上学的时候,导师科研项目中.那时候就是网上找到操作系统移植教程以及应用教程依葫芦画瓢,功能实现也就罢了,没有很深入的去研究过这个东西.后来工作了,闲来无聊就研究了一下这个只 ...
- [转] STM32各种时钟的区别
[原创]:http://m.oschina.net/blog/129357 我在原创的基础又从另一位博主处引用了一些内容. 时钟系统是处理器的核心,所以在学习STM32所有外设之前,认真学习时钟系统是 ...
- [转载]:STM32为什么必须先配置时钟再配置GPIO
转载来源 :http://blog.csdn.net/fushiqianxun/article/details/7926442 [原创]:我来添两句,就是很多同学(包括我)之前搞低端单片机,到了stm ...
- STM32 NVIC配置详解
例程: /* Configure one bit for preemption priority */ NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1) ...
随机推荐
- 熬夜整理出来的干货:Python+Pycharm+PyQT5可视化程序设计入门
前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者:朱淑强 PS:如有需要Python学习资料的小伙伴可以加点击下方链接自 ...
- Numpy学习-(2)
我学习numpy过程的记录 1. 切片和索引 (1) 两种切片方式示例: (2) 多维数组: import numpy as np a = np.array([[1,2,3],[3,4,5],[4,5 ...
- winfrom 基础
1 winfrom就是一种窗体开发端应用程序 2 窗体分类 1)记事本类:可以最大最小化,可以拖拽 窗体默 ...
- python3爬虫 爬取动漫视频
起因 因为本人家里有时候网速不行,所以看动漫的时候播放器总是一卡一卡的,看的太难受了.闲暇无聊又F12看看.但是动漫网站却无法打开控制台.这就勾起了我的兴趣.正好反正无事,去寻找下视频源. 但是这里事 ...
- 《并发编程的艺术》阅读笔记之Lock与AQS
Lock接口 在jdk1.5之后,并发包下新增了一个lock接口,lock接口定义了锁的获取,锁的释放,等方法,需要用户手动设置.与关键字不同的是,lock具有可操作性,比如,可以中断线程,设置超时时 ...
- linux上Docker安装gogs私服亲测(详解)
一.前言 有网友问我为什么要使用私服,可能大部分人都不是太懂,网上那么多存储仓库而且好用方便,但是你想过没有如果企业中的项目,放在人家的仓库上这个安全性不是太好,所以说一般企业都会有自己的私服.本章教 ...
- ES6中对数组的扩展
hello,大家好,我又来了. 前面讲了字符串和数值的扩展,今天要讲的是:数组的扩展.不知道大家能否跟得上这个节奏,你们在阅读中对讲解有存在疑惑,记得留言提出来,要真正地理解,否则白白 ...
- [机器学习实战-Logistic回归]使用Logistic回归预测各种实例
目录 本实验代码已经传到gitee上,请点击查收! 一.实验目的 二.实验内容与设计思想 实验内容 设计思想 三.实验使用环境 四.实验步骤和调试过程 4.1 基于Logistic回归和Sigmoid ...
- JavaScript学习笔记(1)字符串方法
字符串方法 length 属性返回字符串的长度 var txt = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; var sln = txt.length; inde ...
- SOCKET网络基础