智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 3301|回复: 8
打印 上一主题 下一主题

MC9S12XS128芯片利用实现速度控制PID算法

[复制链接]

1

主题

7

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
271
威望
233
贡献
34
兑换币
0
注册时间
2010-4-6
在线时间
2 小时
跳转到指定楼层
1#
发表于 2010-4-8 21:59:17 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
菜鸟恳求骨灰赐教~

4

主题

207

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1993
QQ
威望
1255
贡献
688
兑换币
0
注册时间
2009-11-12
在线时间
25 小时
2#
发表于 2010-4-19 20:23:29 | 只看该作者
新手一起学习
回复 支持 反对

使用道具 举报

1

主题

76

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
336
QQ
威望
293
贡献
37
兑换币
0
注册时间
2010-4-7
在线时间
3 小时
3#
发表于 2010-4-23 20:58:33 | 只看该作者
me  too
回复 支持 反对

使用道具 举报

1

主题

29

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
307
QQ
威望
257
贡献
26
兑换币
0
注册时间
2010-4-29
在线时间
12 小时
4#
发表于 2010-5-3 21:11:15 | 只看该作者
me  too
回复 支持 反对

使用道具 举报

3

主题

5

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
344
威望
287
贡献
47
兑换币
26
注册时间
2009-12-11
在线时间
5 小时
5#
发表于 2010-5-3 22:50:38 | 只看该作者
我这有个程序,但不是很懂,拿来供大家参考一下:
#include <string.h>
#include <stdio.h>
/*====================================================================================================
PID Function
The PID (比例、积分、微分) function is used in mainly
control applications. PIDCalc performs one iteration of the PID
algorithm.
While the PID function works, main is just a dummy program showing
a typical usage.
=====================================================================================================*/
typedef struct PID
{
double SetPoint; // 设定目标 Desired Value
double Proportion; // 比例常数 Proportional Const
double Integral; // 积分常数 Integral Const
double Derivative; // 微分常数 Derivative Const
double LastError; // Error[-1]
double PrevError; // Error[-2]
double SumError; // Sums of Errors
} PID;         定义了一个PID结构体
/*====================================================================================================
PID计算部分
=====================================================================================================*/
double PIDCalc( PID *pp, double NextPoint )
{
double dError,
Error;
Error = pp->SetPoint - NextPoint; // 偏差
pp->SumError += Error; // 积分
dError = pp->LastError - pp->PrevError; // 当前微分
pp->PrevError = pp->LastError;
pp->LastError = Error;
return (pp->Proportion * Error // 比例项
+ pp->Integral * pp->SumError // 积分项
+ pp->Derivative * dError // 微分项
}      链表不是很懂
/*====================================================================================================
Initialize PID Structure
=====================================================================================================*/
void PIDInit (PID *pp)
{
memset ( pp,0,sizeof(PID));
}
/*====================================================================================================
Main Program
=====================================================================================================*/
double sensor (void) // Dummy Sensor Function
{
return 100.0;
}
void actuator(double rDelta) // Dummy Actuator Function
{}
void main(void)
{
PID sPID; // PID Control Structure
double rOut; // PID Response (Output)
double rIn; // PID Feedback (Input)
PIDInit ( &sPID ); // Initialize Structure
sPID.Proportion = 0.5; // Set PID Coefficients
sPID.Integral = 0.5;
sPID.Derivative = 0.0;
sPID.SetPoint = 100.0; // Set PID Setpoint
  for (;;)  // Mock Up of PID Processing
{
rIn = sensor (); // Read Input
rOut = PIDCalc ( &sPID,rIn ); // Perform PID Interation
actuator ( rOut ); // Effect Needed Changes
}
}
回复 支持 反对

使用道具 举报

0

主题

38

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
275
威望
217
贡献
48
兑换币
6
注册时间
2009-9-8
在线时间
5 小时
6#
发表于 2010-7-14 16:27:08 | 只看该作者
回复 支持 反对

使用道具 举报

1

主题

8

帖子

0

精华

高级会员

Rank: 4

积分
795
QQ
威望
236
贡献
547
兑换币
0
注册时间
2010-9-24
在线时间
6 小时
7#
发表于 2010-12-13 10:55:21 | 只看该作者
得先看PID推导公式,自己和书本上的介绍一步一步导出后,再看程序就很简单了
回复 支持 反对

使用道具 举报

4

主题

114

帖子

0

精华

高级会员

Rank: 4

积分
915
威望
366
贡献
117
兑换币
10
注册时间
2010-12-4
在线时间
216 小时
8#
发表于 2010-12-31 11:12:39 | 只看该作者
学习学习!
回复 支持 反对

使用道具 举报

10

主题

304

帖子

0

精华

高级会员

Rank: 4

积分
788
QQ
威望
551
贡献
209
兑换币
0
注册时间
2011-3-10
在线时间
14 小时
9#
发表于 2011-3-16 00:25:05 | 只看该作者
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-16 22:30 , Processed in 0.173645 second(s), 30 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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