找回密码
 立即注册

QQ登录

只需一步,快速开始

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

用ps2手柄控制 stm32F4驱动麦克纳姆轮3D图纸源码资料

[复制链接]
跳转到指定楼层
楼主
ps2手柄控制 stm32f4zgt6芯片驱动麦克纳姆轮资料
这里使用的是PWM调速来完成的,简单的程序,资料和源码在下面。


麦克纳姆轮3D图纸:


单片机源程序如下:
  1. #include <sys.h>
  2. #include <pwm.h>
  3. #include <delay.h>
  4. #include <usart.h>
  5. #include <pstwo.h>

  6. int main(void)
  7. {
  8.         u16 L11=0;   
  9.   u16 L12=0;
  10.         u16 L21=0;   
  11.   u16 L22=0;
  12.         u16 R11=0;   
  13.   u16 R12=0;
  14.         u16 R21=0;   
  15.   u16 R22=0;
  16.         u8 key;       
  17.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//设置系统中断优先级分组2
  18.         delay_init(168);      //初始化延时函数
  19.         uart_init(115200);    //初始化串口波特率为115200
  20.         PWM_init(500-1,84-1);        //84M/84=1Mhz的计数频率,重装载值500,所以PWM频率为 1M/500=2Khz.     
  21.         PS2_Init();
  22.         PS2_SetInit();
  23.        
  24.         while(1)
  25.         {
  26.                 key=PS2_DataKey();
  27.                 if(key!=0)
  28.                 {      
  29.                         switch(key)
  30.                         {
  31.                                 case 5:        //前进
  32.                                 {
  33.                             L11=300;   
  34.           L12=0;
  35.                 L21=300;   
  36.           L22=0;
  37.                 R11=300;   
  38.           R12=0;
  39.           R21=300;   
  40.           R22=0;
  41.           TIM_SetCompare1(TIM14,L11);
  42.           TIM_SetCompare1(TIM13,L12);
  43.           TIM_SetCompare1(TIM11,L21);
  44.           TIM_SetCompare1(TIM10,L22);
  45.           TIM_SetCompare1(TIM3,R11);
  46.           TIM_SetCompare2(TIM3,R12);
  47.           TIM_SetCompare3(TIM3,R21);
  48.           TIM_SetCompare4(TIM3,R22);                                       
  49.                                 }
  50.                                 break;
  51.                                 case 6:        //右平移
  52.                                 {
  53.                 L11=0;   
  54.           L12=300;
  55.                 L21=300;   
  56.           L22=0;
  57.                 R11=300;   
  58.           R12=0;
  59.           R21=0;   
  60.           R22=300;
  61.           TIM_SetCompare1(TIM14,L11);
  62.           TIM_SetCompare1(TIM13,L12);
  63.           TIM_SetCompare1(TIM11,L21);
  64.           TIM_SetCompare1(TIM10,L22);
  65.           TIM_SetCompare1(TIM3,R11);
  66.           TIM_SetCompare2(TIM3,R12);
  67.           TIM_SetCompare3(TIM3,R21);
  68.           TIM_SetCompare4(TIM3,R22);                                       
  69.                                 }
  70.                                 break;
  71.                                 case 8:         //左平移
  72.                                 {
  73.                 L11=300;   
  74.           L12=0;
  75.                 L21=0;   
  76.           L22=300;
  77.                 R11=0;   
  78.           R12=300;
  79.           R21=300;   
  80.           R22=0;
  81.           TIM_SetCompare1(TIM14,L11);
  82.           TIM_SetCompare1(TIM13,L12);
  83.           TIM_SetCompare1(TIM11,L21);
  84.           TIM_SetCompare1(TIM10,L22);
  85.           TIM_SetCompare1(TIM3,R11);
  86.           TIM_SetCompare2(TIM3,R12);
  87.           TIM_SetCompare3(TIM3,R21);
  88.           TIM_SetCompare4(TIM3,R22);                                       
  89.                                 }
  90.                                 break;
  91.                                 case 7:        //后退
  92.                                 {
  93.                 L11=0;   
  94.           L12=300;
  95.                 L21=0;   
  96.           L22=300;
  97.                 R11=0;   
  98.           R12=300;
  99.           R21=0;   
  100.           R22=300;
  101.           TIM_SetCompare1(TIM14,L11);
  102.           TIM_SetCompare1(TIM13,L12);
  103.           TIM_SetCompare1(TIM11,L21);
  104.           TIM_SetCompare1(TIM10,L22);
  105.           TIM_SetCompare1(TIM3,R11);
  106.           TIM_SetCompare2(TIM3,R12);
  107.           TIM_SetCompare3(TIM3,R21);
  108.           TIM_SetCompare4(TIM3,R22);                                       
  109.                                 }
  110.                                 break;
  111.                                 case 9:         //逆时针旋转
  112.                                 {
  113.                 L11=0;   
  114.           L12=300;
  115.                 L21=0;   
  116.           L22=300;
  117.                 R11=300;   
  118.           R12=0;
  119.           R21=300;   
  120.           R22=0;
  121.           TIM_SetCompare1(TIM14,L11);
  122.           TIM_SetCompare1(TIM13,L12);
  123.           TIM_SetCompare1(TIM11,L21);
  124.           TIM_SetCompare1(TIM10,L22);
  125.           TIM_SetCompare1(TIM3,R11);
  126.           TIM_SetCompare2(TIM3,R12);
  127.           TIM_SetCompare3(TIM3,R21);
  128.           TIM_SetCompare4(TIM3,R22);                                       
  129.                                 }
  130.                                 break;
  131.                                 case 10:         //顺时针旋转
  132.                                 {
  133.                 L11=300;   
  134.           L12=0;
  135.                 L21=300;   
  136.           L22=0;
  137.                 R11=0;   
  138.           R12=300;
  139.           R21=0;   
  140.           R22=300;
  141.           TIM_SetCompare1(TIM14,L11);
  142.           TIM_SetCompare1(TIM13,L12);
  143.           TIM_SetCompare1(TIM11,L21);
  144.           TIM_SetCompare1(TIM10,L22);
  145.           TIM_SetCompare1(TIM3,R11);
  146.           TIM_SetCompare2(TIM3,R12);
  147.           TIM_SetCompare3(TIM3,R21);
  148.           TIM_SetCompare4(TIM3,R22);                                       
  149.                                 }
  150.                                 break;
  151.                                 case 13:         //左前
  152.                                 {
  153.                 L11=0;   
  154.           L12=0;
  155.                 L21=300;   
  156.           L22=0;
  157.                 R11=300;   
  158.           R12=0;
  159.           R21=0;   
  160.           R22=0;
  161.           TIM_SetCompare1(TIM14,L11);
  162.           TIM_SetCompare1(TIM13,L12);
  163.           TIM_SetCompare1(TIM11,L21);
  164.           TIM_SetCompare1(TIM10,L22);
  165.           TIM_SetCompare1(TIM3,R11);
  166.           TIM_SetCompare2(TIM3,R12);
  167.           TIM_SetCompare3(TIM3,R21);
  168.           TIM_SetCompare4(TIM3,R22);                                       
  169.                                 }
  170.                                 break;
  171.                                 case 14:         //右前
  172.                                 {
  173.                 L11=300;   
  174.           L12=0;
  175.                 L21=0;   
  176.           L22=0;
  177.                 R11=0;   
  178.           R12=0;
  179.           R21=300;   
  180.           R22=0;
  181.           TIM_SetCompare1(TIM14,L11);
  182.           TIM_SetCompare1(TIM13,L12);
  183.           TIM_SetCompare1(TIM11,L21);
  184.           TIM_SetCompare1(TIM10,L22);
  185.           TIM_SetCompare1(TIM3,R11);
  186.           TIM_SetCompare2(TIM3,R12);
  187.           TIM_SetCompare3(TIM3,R21);
  188.           TIM_SetCompare4(TIM3,R22);                                       
  189.                                 }
  190.                                 break;
  191.                                 case 16:         //左后
  192.                                 {
  193.                 L11=0;   
  194.           L12=0;
  195.                 L21=0;   
  196.           L22=300;
  197.                 R11=0;   
  198.           R12=300;
  199.           R21=0;   
  200.           R22=0;
  201.           TIM_SetCompare1(TIM14,L11);
  202.           TIM_SetCompare1(TIM13,L12);
  203.           TIM_SetCompare1(TIM11,L21);
  204.           TIM_SetCompare1(TIM10,L22);
  205.           TIM_SetCompare1(TIM3,R11);
  206.           TIM_SetCompare2(TIM3,R12);
  207.           TIM_SetCompare3(TIM3,R21);
  208.           TIM_SetCompare4(TIM3,R22);                                       
  209.                                 }
  210.                                 break;
  211.                                 case 15:         //右后
  212.                                 {
  213.                 L11=0;   
  214.           L12=300;
  215.                 L21=0;   
  216.           L22=0;
  217.                 R11=0;   
  218.           R12=0;
  219.           R21=0;   
  220.           R22=300;
  221.           TIM_SetCompare1(TIM14,L11);
  222.           TIM_SetCompare1(TIM13,L12);
  223.           TIM_SetCompare1(TIM11,L21);
  224.           TIM_SetCompare1(TIM10,L22);
  225.           TIM_SetCompare1(TIM3,R11);
  226.           TIM_SetCompare2(TIM3,R12);
  227.           TIM_SetCompare3(TIM3,R21);
  228.           TIM_SetCompare4(TIM3,R22);                                       
  229.                                 }
  230.                                 break;
  231.                         }                               

  232.            }
  233.                         else//停止
  234.                         {
  235.                                   L11=0;   
  236.           L12=0;
  237.                 L21=0;   
  238.           L22=0;
  239.                 R11=0;   
  240.           R12=0;
  241.           R21=0;   
  242.           R22=0;
  243.                                   TIM_SetCompare1(TIM14,L11);
  244.           TIM_SetCompare1(TIM13,L12);
  245.           TIM_SetCompare1(TIM11,L21);
  246.           TIM_SetCompare1(TIM10,L22);
  247.           TIM_SetCompare1(TIM3,R11);
  248.           TIM_SetCompare2(TIM3,R12);
  249.           TIM_SetCompare3(TIM3,R21);
  250.           TIM_SetCompare4(TIM3,R22);
  251.                         }
  252.                         delay_ms(50);
  253.          }
  254.         }
复制代码


  1. #include "main.h"
  2. #include "PID.h"
  3. #include<stdio.h>
  4. #include<math.h>
  5. #include<systick.h>
  6. #include<main.h>


  7. #define Kp 10                                                 //比例系数
  8. #define Ki 10                                         //积分系数
  9. #define Kd 0                                                 //微分系数

  10. #define PID_MAX 12800

  11. uint8_t last_error;                          //上次误差
  12. uint8_t last_error1;                  //上次误差
  13. uint8_t last_error2;                  //上次误差

  14. float I_term;                                                  //前面温差和
  15. float I_term1;                                          //前面温差和
  16. float I_term2;                                          //前面温差和

  17. u16 PWMA_Num =0;
  18. u16        PWMB_Num =0;
  19. u16 PWMC_Num =0;

  20. //unsigned int out;//,PWMT;
  21. //unsigned int out1//,PWMT;

  22. int PID(int Set_value,int Real_value) //标准PID温度控制算法
  23. {
  24.         int error;
  25.         float P_term, D_term;
  26.         int pid_out;
  27.         error=Set_value - Real_value;                                                                                                //误差量
  28.   //if(error<1000)
  29.   //{
  30.                 P_term =Kp*error;                                                                                                                                 //比例量
  31.                 I_term+=Ki*error;                                                                                                                                 //积分量
  32.                 if(I_term>PID_MAX) I_term=PID_MAX;                                                                 //限定积分量上限
  33.                 else if(I_term<0) I_term=0;                                                                                   //限定积分量下限
  34.                 D_term =Kd*(error - last_error);                                                                  //微分量
  35.                 last_error=error;                                                                                                                                 //缓存当前误差量
  36.                 if(error<20)I_term=130;
  37.                 else I_term=0;
  38.                 pid_out=(signed int)(P_term+I_term+D_term);                         //PID控制量计算
  39.   
  40.                 if(pid_out>PID_MAX) pid_out=PID_MAX;                                                  //控制量上限=PID_MAX
  41.                 else if(pid_out<0) pid_out=0;                                                                            //控制量下限=0
  42.                 //return(pid_out);
  43.   //}
  44.   //else if(error>=1000) pid_out=12800;
  45.    
  46.   return(pid_out);
  47. }

  48. int PID1(int Set_value,int Real_value) //标准PID温度控制算法
  49. {
  50.         int error;
  51.         float P_term, D_term;
  52.         int pid_out;
  53.         error=Set_value - Real_value;                                                                                                //误差量
  54.   //if(error<1000)
  55.   //{
  56.                 P_term =Kp*error;                                                                                                                                 //比例量
  57.                 I_term1+=Ki*error;                                                                                                                                 //积分量
  58.                 if(I_term1>PID_MAX) I_term1=PID_MAX;                                                                 //限定积分量上限
  59.                 else if(I_term1<0) I_term1=0;                                                                                   //限定积分量下限
  60.                 D_term =Kd*(error - last_error1);                                                                  //微分量
  61.                 last_error1=error;                                                                                                                                 //缓存当前误差量
  62.                 if(error<20)I_term1=130;
  63.                 else I_term1=0;
  64.                 pid_out=(signed int)(P_term+I_term1+D_term);                         //PID控制量计算
  65.   
  66.                 if(pid_out>PID_MAX) pid_out=PID_MAX;                                                  //控制量上限=PID_MAX
  67.                 else if(pid_out<0) pid_out=0;                                                                            //控制量下限=0
  68.                 //return(pid_out);
  69.   //}
  70.   //else if(error>=1000) pid_out=12800;
  71.    
  72.   return(pid_out);
  73. }

  74. int PID2(int Set_value,int Real_value) //标准PID温度控制算法
  75. {
  76.         int error;
  77.         float P_term, D_term;
  78.         int pid_out;
  79.         error=Set_value - Real_value;                                                                                                //误差量
  80.   //if(error<1000)
  81.   //{
  82.                 P_term =Kp*error;                                                                                                                                 //比例量
  83.                 I_term2+=Ki*error;                                                                                                                                 //积分量
  84.                 if(I_term2>PID_MAX) I_term2=PID_MAX;                                                                 //限定积分量上限
  85.                 else if(I_term2<0) I_term2=0;                                                                                   //限定积分量下限
  86.                 D_term =Kd*(error - last_error2);                                                                  //微分量
  87.                 last_error2=error;                                                                                                                                 //缓存当前误差量
  88.                 if(error<20)I_term2=130;
  89.                 else I_term2=0;
  90.                 pid_out=(signed int)(P_term+I_term2+D_term);                         //PID控制量计算
  91.   
  92.                 if(pid_out>PID_MAX) pid_out=PID_MAX;                                                  //控制量上限=PID_MAX
  93.                 else if(pid_out<0) pid_out=0;                                                                            //控制量下限=0
  94.                 //return(pid_out);
  95.   //}
  96.   //else if(error>=1000) pid_out=12800;
  97.    
  98.   return(pid_out);
  99. }

  100. void jiare_pid_kongzhi(void)
  101. {
  102.         uint16_t goal_temp=0;//目标温度
  103.         //PWMT=12800;                                                                                                                                                           //128级步进PWM控制  
  104.         //PID_MAX=PWMT;

  105.         uint16_t out=0;
  106.         I_term=0;
  107.         last_error=0;
  108.         if (WorkFaceDisBuff[10]==0)//现场测试华氏不加热 增加温度单位转换 目标温度是摄氏和华氏分开存放的 2017年12月6日 09:16:22
  109.         {
  110.                 goal_temp = (WorkFaceDisBuff[3]+0)*100;//之前的是+3 会导致PWM值超过目标温度值3度的时候才停止 可能需要PID数值才是正确方法 2017年11月30日 15:04:01
  111.         }
  112.         else
  113.         {
  114.                 goal_temp = (WorkFaceDisBuff[11]+0)*100;//之前的是+3 会导致PWM值超过目标温度值3度的时候才停止 可能需要PID数值才是正确方法 2017年11月30日 15:04:01
  115.         }
  116.         out=PID(goal_temp,WorkFaceDisBuff[4]);                                                                                                                          //PID程序
  117.         PWMA_Num= (out/100);                                                                                                                 //PWM值
  118. }  

  119. void jiare_pid_kongzhi1(void)
  120. {
  121.         uint16_t goal_temp=0;//目标温度
  122.         //PWMT=12800;                                                                                                                                                           //128级步进PWM控制  
  123.         //PID_MAX=PWMT;

  124.         uint16_t out=0;
  125.         I_term1=0;
  126.         last_error1=0;
  127.        
  128.         if (WorkFaceDisBuff[10]==0)//现场测试华氏不加热 增加温度单位转换 目标温度是摄氏和华氏分开存放的 2017年12月6日 09:16:22
  129.         {
  130.                 goal_temp = (WorkFaceDisBuff[5]+0)*100;//之前的是+3 会导致PWM值超过目标温度值3度的时候才停止 可能需要PID数值才是正确方法 2017年11月30日 15:04:01
  131.         }
  132.         else
  133.         {
  134.                 goal_temp = (WorkFaceDisBuff[12]+0)*100;//之前的是+3 会导致PWM值超过目标温度值3度的时候才停止 可能需要PID数值才是正确方法 2017年11月30日 15:04:01
  135.         }
  136.         out=PID1(goal_temp,WorkFaceDisBuff[6]);                                                                                                                          //PID程序
  137.         PWMB_Num= (out/100);                                                                                                                 //PWM值
  138. }  

  139. void jiare_pid_kongzhi2(void)
  140. {
  141.         uint16_t goal_temp=0;//目标温度
  142. //        //PWMT=12800;                                                                                                                                                           //128级步进PWM控制  
  143. //        //PID_MAX=PWMT;

  144. //        uint16_t out=0;
  145. //        I_term2=0;
  146. //        last_error2=0;
  147.        
  148.         if (WorkFaceDisBuff[10]==0)//现场测试华氏不加热 增加温度单位转换 目标温度是摄氏和华氏分开存放的 2017年12月6日 09:16:22
  149.         {
  150.                 goal_temp = (WorkFaceDisBuff[7]+0)*100;//之前的是+3 会导致PWM值超过目标温度值3度的时候才停止 可能需要PID数值才是正确方法 2017年11月30日 15:04:01
  151.         }
  152.         else
  153.         {
  154.                 goal_temp = (WorkFaceDisBuff[13]+0)*100;//之前的是+3 会导致PWM值超过目标温度值3度的时候才停止 可能需要PID数值才是正确方法 2017年11月30日 15:04:01
  155.         }
  156. //        out=PID1(goal_temp,WorkFaceDisBuff[8]);                                                                                                                          //PID程序
  157. //        PWMC_Num= (out/100);                                                                                                                 //PWM值
  158.         if (goal_temp>WorkFaceDisBuff[8])//将PWM转化为开关量了 因为C路是继电器控制的
  159.         {
  160.                 PWMC_Num=129;//永远大于128
  161.         }
  162.         else
  163.         {
  164.                 PWMC_Num=0;
  165.         }
  166. }  
复制代码

所有资料51hei提供下载:
2018.9.28 TIM3backup.rar (459.3 KB, 下载次数: 76)
纳姆车资料 STM32源码+3D图纸.7z (4.45 MB, 下载次数: 99)


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

使用道具 举报

沙发
ID:305426 发表于 2018-11-30 17:26 | 只看该作者
正好要用呐。想问下这个经过测试了咩,PID控制可靠么~
回复

使用道具 举报

板凳
ID:305426 发表于 2018-11-30 17:47 | 只看该作者
下载来看了一下,原来是开环控制…失望…
回复

使用道具 举报

地板
ID:243337 发表于 2019-4-9 08:51
下载的程序打不开。

5#
ID:537157 发表于 2019-5-21 16:12 | 只看该作者
不知道你这个东西能干嘛?还以为是PS2的东西,
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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