4001
- 收藏
- 点赞
- 分享
- 举报
STM32的PID例程
这是我自己写的关于pid的一个位置式算法的部分,在处理程序中用了比较简单的单纯的返回一个值,可以根据自己的需要改写一下。。。
定义PID结构体,包含了计算中用到的各种变量
=====================================================================================================*/
typedef struct PID
{
double SetPoint; // 设定目标值r(t) Desired Value
double Proportion; // 比例常数k(p) Proportional Const
double Integral; // 积分常数k(i) Integral Const
double Derivative; // 微分常数k(d) Derivative Const
double LastError; // 微分部分的 最新偏差e(k) Error[-1]
double PrevError; // 微分部分的 最新偏差e(k-1) Error[-2]
double SumError; // 积分部分的 累加偏差 Sums of Errors
}PID;
/*====================================================================================================
Initialize PID Structure----对定义的PID结构体类型的pp所占用的地址空间都给清零
=====================================================================================================*/
void PIDInit(PID *pp)
{
memset ( pp,0,sizeof(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);
// 比例项部分 + 积分项部分 + 微分项部分
}
/*====================================================================================================
PID计算部分----增量式PID算法
=====================================================================================================*/
double PIDCalc_delt( PID *pp, double NextPoint )
{
double dError, Error;
Error = pp->SetPoint - NextPoint; // 比例部分的 最新一次采样计算的偏差
dError= pp->Proportion * Error + pp->Integral * pp->LastError + pp->Derivative * pp->PrevError;
pp->PrevError = pp->LastError; // 微分部分的 更新上一次偏差为最新偏差
pp->LastError = Error;
return (dError);
}
/*====================================================================================================
PID计算部分----PID处理部分
=====================================================================================================*/
uint32_t actuator(double rDelta) // Dummy Actuator Function 根据计算结果u进行处理
{
return 0;
}
定义PID结构体,包含了计算中用到的各种变量
=====================================================================================================*/
typedef struct PID
{
double SetPoint; // 设定目标值r(t) Desired Value
double Proportion; // 比例常数k(p) Proportional Const
double Integral; // 积分常数k(i) Integral Const
double Derivative; // 微分常数k(d) Derivative Const
double LastError; // 微分部分的 最新偏差e(k) Error[-1]
double PrevError; // 微分部分的 最新偏差e(k-1) Error[-2]
double SumError; // 积分部分的 累加偏差 Sums of Errors
}PID;
/*====================================================================================================
Initialize PID Structure----对定义的PID结构体类型的pp所占用的地址空间都给清零
=====================================================================================================*/
void PIDInit(PID *pp)
{
memset ( pp,0,sizeof(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);
// 比例项部分 + 积分项部分 + 微分项部分
}
/*====================================================================================================
PID计算部分----增量式PID算法
=====================================================================================================*/
double PIDCalc_delt( PID *pp, double NextPoint )
{
double dError, Error;
Error = pp->SetPoint - NextPoint; // 比例部分的 最新一次采样计算的偏差
dError= pp->Proportion * Error + pp->Integral * pp->LastError + pp->Derivative * pp->PrevError;
pp->PrevError = pp->LastError; // 微分部分的 更新上一次偏差为最新偏差
pp->LastError = Error;
return (dError);
}
/*====================================================================================================
PID计算部分----PID处理部分
=====================================================================================================*/
uint32_t actuator(double rDelta) // Dummy Actuator Function 根据计算结果u进行处理
{
return 0;
}
我来回答
回答0个
时间排序
认可量排序
暂无数据
或将文件直接拖到这里
悬赏:
E币
网盘
* 网盘链接:
* 提取码:
悬赏:
E币
Markdown 语法
- 加粗**内容**
- 斜体*内容*
- 删除线~~内容~~
- 引用> 引用内容
- 代码`代码`
- 代码块```编程语言↵代码```
- 链接[链接标题](url)
- 无序列表- 内容
- 有序列表1. 内容
- 缩进内容
- 图片![alt](url)
相关问答
-
2013-08-25 00:35:00
-
2014-03-20 19:27:36
-
2013-11-21 21:46:40
-
2013-11-21 16:43:55
-
2013-08-24 20:13:22
-
2013-08-25 00:03:05
-
2013-08-24 13:30:06
-
2013-08-27 21:56:22
-
2013-08-27 21:59:56
-
2013-08-27 13:35:24
-
2013-08-26 23:30:31
-
2013-11-23 08:55:19
-
02013-08-24 22:15:18
-
2013-11-18 11:08:00
-
2013-12-10 20:37:15
-
2013-11-20 20:47:19
-
2014-04-08 23:35:47
-
2013-08-24 20:25:56
-
2013-11-17 10:43:15
无更多相似问答 去提问
点击登录
-- 积分
-- E币
提问
—
收益
—
被采纳
—
我要提问
切换马甲
上一页
下一页
悬赏问答
-
5SS928的emmc有32GB,bootargs设置使用16GB,但是为啥能用的只有rootfs的大小
-
33SS928怎样烧写ubuntu系统
-
10ToolPlatform下载rootfs提示网络失败
-
10谁有GK7205V500的SDK
-
5Hi3516CV610 烧录不进去
-
10Hi3559AV100 芯片硬解码h265编码格式的视频时出现视频播放错误,解码错误信息 s32PackErr:码流有错
-
5海思SS928 / SD3403的sample_venc.c摄像头编码Demo中,采集到的摄像头的YUV数据在哪个相关的函数中?
-
5海鸥派openEuler无法启动网卡,连接WIFI存在问题
-
66有没有ISP相关的巨佬帮忙看看SS928对接IMX347的图像问题
-
50求助hi3559与FPGA通过SLVS-EC接口对接问题
举报反馈
举报类型
- 内容涉黄/赌/毒
- 内容侵权/抄袭
- 政治相关
- 涉嫌广告
- 侮辱谩骂
- 其他
详细说明
提醒
你的问题还没有最佳答案,是否结题,结题后将扣除20%的悬赏金
取消
确认
提醒
你的问题还没有最佳答案,是否结题,结题后将根据回答情况扣除相应悬赏金(1回答=1E币)
取消
确认