如何在STM32上实现增量PID控制.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
如何在STM32上实现增量PID控制

【教程】如何在STM32上实现增量式PID转? 虽然PID不是什么牛逼的东西,但是真心希望以后刚刚接触这块的人能尽快进入状态。特地分享一些自己如何实现的过程。 首先说说增量式PID的公式,这个关系到MCU算法公式的书写,实际上两个公式的写法是同一个公式变换来得,不同的是系数的差异。 资料上比较多的是: ? 还有一种的算法是: ? 这里主要介绍第二种,具体会分析比例、积分、微分三个环节的作用。 硬件部分: 控制系统的控制对象是4个空心杯直流电机,电机带光电编码器,可以反馈转速大小的波形。电机驱动模块是普通的L298N模块。 芯片型号,STM32F103ZET6 软件部分: PWM输出:TIM3,可以直接输出4路不通占空比的PWM波 PWM捕获:STM32除了TIM6 TIM7其余的都有捕获功能,使用TIM1 TIM2 TIM4 TIM5四个定时器捕获四个反馈信号 PID的采样和处理:使用了基本定时器TIM6,溢出时间就是我的采样周期,理论上T越小效果会越好,这里我取20ms,依据控制对象吧,如果控制水温什么的采样周期会是几秒几分钟什么的。 上面的PWM输出和捕获关于定时器的设置都有例程,我这里是这样的: TIM3输出四路PWM,在引脚 C 的 GPIO_Pin_6 | GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9输出 四路捕获分别是TIM4??TIM1??TIM2??TIM5? ?,对应引脚是:??PB7 PE11 PB3 PA1 高级定时器tim1的初始化略不同,它的中断”名称“和通用定时器不同。具体的内容,请大家看一下我分享的代码就明白了。 ?主要讲解PID部分 准备部分:先定义PID结构体: typedef struct? { int setpoint;//设定目标 int sum_error;//误差累计 float proportion ;//比例常数 float integral ;//积分常数 float derivative;//微分常数 int last_error;//e[-1] int prev_error;//e[-2] }PIDtypedef; 复制代码 在文件中定义几个关键变量: float??Kp =? ???0.32??; //比例常数 float??Ti =? ?? ?? ?? ?? ? 0.09 ; //积分时间常数 float Td =? ?? ?? ?? ?? ? 0.0028 ;??//微分时间常数 #define T? ?? ?? ?? ?? ?? ?0.02 //采样周期 #define Ki? ???Kp*(T/Ti)? ?? ???// Kp Ki Kd 三个主要参数 #define Kd? ?? ?? ?? ?? ? Kp*(Td/T) 复制代码 PID.H里面主要的几个函数: void PIDperiodinit(u16 arr,u16 psc);? ?? ???//PID 采样定时器设定 void incPIDinit(void);? ?? ?? ?? ?? ? //初始化,参数清零清零 int incPIDcalc(PIDtypedef*PIDx,u16 nextpoint);? ?? ?? ???//PID计算 void PID_setpoint(PIDtypedef*PIDx,u16 setvalue);??//设定 PID预期值 void PID_set(float pp,float ii,float dd);//设定PID??kp ki kd三个参数 void set_speed(float W1,float W2,float W3,float W4);//设定四个电机的目标转速 复制代码 PID处理过程: 岔开一下:这里我控制的是电机的转速w,实际上电机的反馈波形的频率f、电机转速w、控制信号PWM的占空比a三者是大致线性的正比的关系,这里强调这个的目的是 因为楼主在前期一直搞不懂我控制的转速怎么和TIM4输出的PWM的占空比联系起来,后来想清楚里面的联系之后通过公式把各个系数算出来了。 正题:控制流程是这样的,首先我设定我需要的车速(对应四个轮子的转速),然后PID就是开始响应了,它先采样电机转速,得到偏差值E,带入PID计算公式,得到调整量也就是最终更改了PWM的占空比,不断调节,直到转速在稳态的一个小范围上下浮动。 上面讲到的“得到调整量”就是增量PID的公式: int incPIDcalc(PIDtypedef *PIDx,u16 nextpoint) { int iError,iincpid; iError=PIDx-setpoint-nextpoint;??//当前误差 /*iincpid=?

文档评论(0)

baoyue + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档