找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1678|回复: 0
打印 上一主题 下一主题
收起左侧

STM32三轮PID闭环代码

[复制链接]
跳转到指定楼层
楼主
ID:640768 发表于 2021-8-6 10:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include "pid.h"
  2. #include "encoder.h"
  3. #include "stm32f10x.h"


  4. int V_encoder_TIM3(void)//1电机速度计算 转/秒
  5. {
  6.         int cnt1;
  7.         cnt1=((int16_t)TIM3->CNT);
  8.         TIM3->CNT=0;
  9.         return cnt1;
  10. }


  11. int User_PidSpeedControl1(float SpeedTag)
  12. {
  13. float control1=0;
  14. float kp=450;   
  15. float ki=1;   
  16. float kd=1;
  17. float errILim=999;
  18. float errNow;
  19. float errOld=0;
  20. float errP=0;
  21. float errI=0;
  22. float errD=0;
  23. float spdNow1;
  24. float s;
  25. spdNow1=s;
  26. errNow =SpeedTag*1.1 - spdNow1;
  27. errP=errNow;
  28. errI+=errNow;
  29. if(errILim != 0)        
  30. {
  31.   if(errI >=  errILim)    errI =  errILim;
  32.   else if(errI <= -errILim)   errI = -errILim;
  33. }
  34. errD= errNow - errOld;
  35. errOld = errNow;        
  36. control1= kp * errP + ki * errI + kd * errD;

  37.    if(control1 >= 1000)  control1 =   1000-1 ;//上限 CCR的值必须小于或等于ARR的值
  38.          if(control1 <=-1000)  control1 = -(1000-1);//下限


  39.          if(control1>=0.0) { GPIO_SetBits(GPIOC,GPIO_Pin_4);         GPIO_ResetBits(GPIOC,GPIO_Pin_5);  }
  40.          else {GPIO_SetBits(GPIOC,GPIO_Pin_5);         GPIO_ResetBits(GPIOC,GPIO_Pin_4);}
  41.          if(control1 <0)  control1 =-control1;//下限  
  42.          
  43.          if(s<=0.1&&s>=-0.1&&SpeedTag==0)TIM_SetCompare1(TIM8,0);
  44.    else TIM_SetCompare1(TIM8,control1);//放入PWM
  45.          
  46.          
  47.          return (int)control1;
  48. }



复制代码

  1. #include "encoder.h"
  2. #include "usart.h"        
  3. #include "delay.h"


  4. void TIM3_Configuration(void)//1编码器接口设置(TIM3)/PA6-A相  PA7-B相
  5. {
  6.   GPIO_InitTypeDef GPIO_InitStructure;
  7.         TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
  8.         TIM_ICInitTypeDef  TIM_ICInitStructure;
  9.         
  10.         RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);
  11.         RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);
  12.          RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA , ENABLE);  //使能GPIOA外设时钟
  13.                                                                                                
  14.         GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6|GPIO_Pin_7;
  15.         GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU;          //设置为上拉输入模式
  16.         GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;           //IO口的速率为50M
  17.         GPIO_Init(GPIOA, &GPIO_InitStructure);                                   //IO口配置函数


  18.   TIM_TimeBaseStructure.TIM_Period =PWMPeriod; //设置在下一个更新事件装入活动的自动重装载寄存器周期的值
  19.         TIM_TimeBaseStructure.TIM_Prescaler = 0; //设置用来作为TIMx时钟频率除数的预分频值  不分频
  20.         TIM_TimeBaseStructure.TIM_ClockDivision = 0;     //设置时钟分割
  21.         TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式
  22.         TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure);
  23.         
  24.         //设置定时器3为编码器模式  IT1 IT2为上升沿计数
  25.         TIM_EncoderInterfaceConfig(TIM3, TIM_EncoderMode_TI12,TIM_ICPolarity_Rising,TIM_ICPolarity_Rising);
  26.         TIM_ICStructInit(&TIM_ICInitStructure);
  27.     TIM_ICInitStructure.TIM_ICFilter = 0;      //输入滤波器
  28.     TIM_ICInit(TIM3, &TIM_ICInitStructure);
  29.     TIM_ClearFlag(TIM3, TIM_FLAG_Update);      //清除所有标志位
  30.     TIM_ITConfig(TIM3, TIM_IT_Update, ENABLE); //允许中断更新
  31.     TIM3->CNT = 0;
  32.         TIM_Cmd(TIM3, ENABLE);
  33. }
复制代码

如有错误,请大家多多指导,代码仅供参考:
stm32三轮PID闭环算法.7z (186.31 KB, 下载次数: 29)

评分

参与人数 1黑币 +20 收起 理由
admin + 20 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表