智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 29840|回复: 101
打印 上一主题 下一主题

[电机与驱动] 一个简单的PID

  [复制链接]

4

主题

22

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
318
威望
265
贡献
21
兑换币
0
注册时间
2009-11-21
在线时间
16 小时
跳转到指定楼层
1#
发表于 2010-3-3 16:59:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式


复制代码

#include <hidef.h>      /* common defines and macros */
#include "derivative.h"      /* derivative-specific definitions */
#include <mc9s12xs128.h>
//定义PID参数
#define VV_KPVALUE 3       //比例
#define VV_KIVALUE 40     //积分
#define VV_KDVALUE 3     //微分
#define VV_MAX 10000       //返回的最大值,是pwm的周期值
#define VV_MIN 0
#define VV_DEADLINE 0X08   //速度PID,设置死区范围
typedef struct PID       //定义数法核心数据
{
signed int vi_Ref;      //速度PID,速度设定值
signed int vi_FeedBack;  //速度PID,速度反馈值


signed long vi_PreError;  //速度PID,前一次,速度误差,,vi_Ref - vi_FeedBack
signed long vi_PreDerror; //速度PID,前一次,速度误差之差,d_error-PreDerror;


unsigned int v_Kp;      //速度PID,Ka = Kp
unsigned int v_Ki;      //速度PID,Kb = Kp * ( T / Ti )
unsigned int v_Kd;      //速度PID,
   
signed long vl_PreU;    //电机控制输出值
  
}PID;
PID  sPID;                //  PID Control Structure

void PIDInit(void)
{
sPID.vi_Ref = 0 ;        //速度设定值
sPID.vi_FeedBack = 0 ;  //速度反馈值
  
sPID.vi_PreError = 0 ;   //前一次,速度误差,,vi_Ref - vi_FeedBack
sPID.vi_PreDerror = 0 ;   //前一次,速度误差之差,d_error-PreDerror;

sPID.v_Kp = VV_KPVALUE;
sPID.v_Ki = VV_KIVALUE;
sPID.v_Kd = VV_KDVALUE;
  
sPID.vl_PreU = 0 ;      //电机控制输出值
}                                   
unsigned int v_PIDCalc( PID *pp )
{
signed long  error,d_error,dd_error;
   
  error = (signed long)(pp->vi_Ref - pp->vi_FeedBack); // 偏差计算   
  d_error = error - pp->vi_PreError;
  dd_error = d_error - pp->vi_PreDerror;
  pp->vi_PreError = error; //存储当前偏差
pp->vi_PreDerror = d_error;
if( ( error < VV_DEADLINE ) && ( error > -VV_DEADLINE ) ); //设置调节死区
              //速度PID计算
  pp->vl_PreU += (signed long)(  pp -> v_Kp * d_error + pp -> v_Ki * error  + pp->v_Kd*dd_error);
  
else if( pp->vl_PreU >= VV_MAX )   //速度PID,防止调节最高溢出
  pp->vl_PreU = VV_MAX;
  
else if( pp->vl_PreU <= VV_MIN ) //速度PID,防止调节最低溢出
  pp->vl_PreU = VV_MIN;
else
;
   return ( pp->vl_PreU  );  // 返回预调节占空比

}



void main(void) {
  /* put your own code here */
  
   InitMCu();
    IncPIDInit();
int g_CurrentVelocity=0;   //全局变量也初始化
int g_Flag=0;                //全局变量也初始化

EnableInterrupts;
  While(1)
{
   if (g_Flag&&vi_FeedBack)
      {
          PWMOUT+=  v_PIDCalc( PID *pp );
            g_Flag&=~ vi_FeedBack;
}
}
}
  for(;;) {
    _FEED_COP(); /* feeds the dog */
  } /* loop forever */
  /* please make sure that you never leave main */
}

1

主题

19

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
289
QQ
威望
245
贡献
20
兑换币
0
注册时间
2010-2-24
在线时间
12 小时
2#
发表于 2010-3-5 12:38:40 | 只看该作者
学习学习
回复 支持 反对

使用道具 举报

0

主题

162

帖子

0

精华

高级会员

Rank: 4

积分
537
QQ
威望
351
贡献
160
兑换币
12
注册时间
2009-9-26
在线时间
13 小时
3#
发表于 2010-3-5 15:46:03 | 只看该作者
学习了
回复 支持 反对

使用道具 举报

0

主题

59

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
308
威望
229
贡献
35
兑换币
0
注册时间
2009-3-8
在线时间
22 小时
4#
发表于 2010-3-6 20:06:26 | 只看该作者
学习了
回复 支持 反对

使用道具 举报

0

主题

59

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
308
威望
229
贡献
35
兑换币
0
注册时间
2009-3-8
在线时间
22 小时
5#
发表于 2010-3-6 20:14:08 | 只看该作者
好好待我分析下
回复 支持 反对

使用道具 举报

8

主题

187

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2437

活跃会员奖章优秀会员奖章在线王奖章

威望
1104
贡献
705
兑换币
14
注册时间
2009-4-18
在线时间
314 小时
6#
发表于 2010-3-9 11:54:30 | 只看该作者
好好 研究一下
回复 支持 反对

使用道具 举报

49

主题

489

帖子

0

精华

金牌会员

董事长

Rank: 6Rank: 6

积分
2370
威望
754
贡献
1130
兑换币
0
注册时间
2009-10-30
在线时间
243 小时
7#
发表于 2010-3-9 13:38:01 | 只看该作者
学习学习
回复 支持 反对

使用道具 举报

0

主题

14

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
206
威望
184
贡献
20
兑换币
0
注册时间
2010-3-8
在线时间
1 小时
8#
发表于 2010-3-9 17:11:01 | 只看该作者
seesee
回复 支持 反对

使用道具 举报

3

主题

54

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
286
威望
228
贡献
28
兑换币
0
注册时间
2010-3-5
在线时间
15 小时
9#
发表于 2010-3-9 22:19:13 | 只看该作者
谢谢~刚开始学呢~先分享再说~呵呵
回复 支持 反对

使用道具 举报

0

主题

2

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
230
威望
190
贡献
36
兑换币
12
注册时间
2010-3-9
在线时间
2 小时
10#
发表于 2010-3-9 22:43:01 | 只看该作者
我刚开始玩智能车,这个收藏了,
另外,谢谢
回复 支持 反对

使用道具 举报

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

本版积分规则

关于我们|联系我们|小黑屋|智能车制作 ( 黑ICP备2022002344号

GMT+8, 2024-11-9 00:53 , Processed in 0.208193 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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