0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

浅谈PID微分器与滤波器

传感器技术 来源:传感器技术 作者:传感器技术 2020-10-13 12:01 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

0 前面的话

这篇文章肝了好久,控制有时候给人的感觉是披着数学外衣的,但是脱下外衣,发现还是控制,本文有一些基本的推导,无非是为最后的算法C实现做铺垫,最终目的是能在实践中进行应用和系统调优。

目录

0 前面的话

目录

1 先说噪声

2 噪声对于系统的影响

3 对于PID控制器的影响

4 加入滤波器

4.1 传递函数

4.2 串联微分的等效形式反馈积分

5 C语言实现

6 参考

1 先说噪声

在电子设备等电路系统中,噪声是不被系统需要的电信号;电子设备产生的噪声会由于多种不同的影响而产生很大的差异。在通信系统中,噪声是一个错误或不希望出现的随机干扰从而作用于有效的信号。

2 噪声对于系统的影响

噪声出现的第一个场景,当我们在教室里做英语听力,然后旁边的同学手机忽然来了一条短信,这时候往往可以听到放英语听力的喇叭会被干扰,然后会发出哔哔哔的声音;

下面是一个正弦信号跌加噪声的例子,在原始信号上叠加一定幅度的高斯噪声,可以看到信号不再像原来的正弦信号那样完美,具体如下图所示;

或者,很久很久以前,数字电视还没有普及,那时候的显像管的黑白电视,也容易出现这样的雪花一样的噪声,叠加在图片上就会出现这样的效果,具体如下图所示;

从上述的例子中可以看到,噪声往往会对系统造成一定程度的影响,但是如果噪声的幅度减小到一定程度,对于系统的影响可能就没有那么容易被发现。

下面做一个实验;在一张黑色图片上叠加幅度很小幅度的高斯噪声;从第二张图片中发现噪声没有影响到整体图片;

然后我尝试提高了整幅图片的亮度,发现,噪点便开始出来了,这像极平时那些枪版影片的马赛克画质;整体的实验结果如下图所示;

3 对于PID控制器的影响

既然噪声的幅度减小到一定程度,对于系统的影响可能就没有那么容易被发现,那么对理想的PID控制器又有什么影响呢?

不要忘了,在理想PID控制器中,微分控制器会对偏差的变化率(斜率)进行累加,从而产生积分器的输出;

对于微分器来说,即使噪声幅度足够小,但是只要达到足够高频率,偏差的变化率一样可以变得很大,下面举个例子;

这里有一个固定频率和赋值的噪声为信号1,这个信号可以表示为:

于是我们尝试将信号1的幅度减半,频率变为原来的两倍,得到了信号2:

以此类推,在信号2的基础上,幅度再减半,频率乘以2,得到信号3:

简单画了一下这个信号,具体如下图所示;

假设分别取三个信号位于该点的斜率,从图中可以看到,斜率1,斜率2,斜率3是相同的,简单验证一下,在时刻,可以得到:

所以这里就是求复合函数的微分,由于选取的点比较特殊,发现最终计算得到的结果,因此也可以发现,即使减小了噪声的幅度,但是对于较高频率的噪声,依然会产生较大斜率。

遇到高频噪声,那么微分器会产生较大的输出,从而最终对系统造成影响,这是我们不希望出现的结果,因此在反馈回路中并不希望高频噪声进入PID控制器的计算,这里就需要低通滤波器将噪声滤除。

4 加入滤波器

低通滤波器可以滤除高频信号,这样保留了有效信号,可以设置所需的截止频率;系统处理有效信号,由于低频部分信噪比较高,因此噪声对于系统的影响较小,而高频部分,信噪比就很低,这时候对于系统来说,噪声就会造成不小的影响,具体如下图所示;

信噪比:有效信号和噪声的比值,英文名称叫做SNR或S/N(SIGNAL-NOISE RATIO);

所以下面我们会在PID控制器的微分部分加入低通滤波器,这样对反馈的信号进行一部分处理,从而减小系统干扰,如下图所示;

4.1 传递函数

概念:拉普拉斯变换是对于 函数值不为零的连续时间函数 通过关系式 (式中为自然对数底的指数)变换为复变量的函数。它也是时间函数的“复频域”表示方式。

也就是说拉式变换可以将时域关系变换到频域中,这样可以便于系统进行分析。

下面是本文下面会用到的时域函数对应的拉普拉斯变换:

积分:

微分:

低通滤波器的传递函数:

低通滤波器中的截止频率即为,单位是;

4.2 串联微分的等效形式反馈积分

串联等效传递函数的关系为,两个方框串联等于各个方框传递函数的乘积;具体如下所示;

因此低通滤波串联微分的传递函数为:

闭环负反馈的等效传递函数的关系如下所示;

这里我们可以使用负反馈积分的方式,构建等效于串联微分的传递函数,最终的传递函数结果是相同的,具体如下图所示;

串联微分的形式,可能在算法的实现上会更加直观,但是会比较费资源;

使用负反馈积分的等效形式进行实现,则进一步减少了算法的资源消耗,下面给出一个TI公司的PID算法实现就是通过负反馈积分的等效形式进行实现的。

5 C语言实现

这里直接使用了TI公司的PID算法,对于微分部分做了滤波的处理,并且使用的是负反馈积分的方式,具体可以参考controlSUITElibsapp_libsmotor_controlmath_blocksv4.2pid_grando.hPID控制器的整体框图如下所示,我们只关心微分部分;

首先可以发现满足:

这里滤波器有两个系数和,它们必须满足截止频率(单位Hz)和采样周期(单位秒)以下的关系:

C语言实现如下:

/*================================================================================= Filename:PID_GRANDO.H ===================================================================================*/ #ifndef__PID_H__ #define__PID_H__ typedefstruct{_iqRef;//Input:referenceset-point _iqFbk;//Input:feedback _iqOut;//Output:controlleroutput _iqc1;//Internal:derivativefiltercoefficient1 _iqc2;//Internal:derivativefiltercoefficient2 }PID_TERMINALS; //note:c1&c2placedheretokeepstructuresizeunder8words typedefstruct{_iqKr;//Parameter:referenceset-pointweighting _iqKp;//Parameter:proportionalloopgain _iqKi;//Parameter:integralgain _iqKd;//Parameter:derivativegain _iqKm;//Parameter:derivativeweighting _iqUmax;//Parameter:uppersaturationlimit _iqUmin;//Parameter:lowersaturationlimit }PID_PARAMETERS; typedefstruct{_iqup;//Data:proportionalterm _iqui;//Data:integralterm _iqud;//Data:derivativeterm _iqv1;//Data:pre-saturatedcontrolleroutput _iqi1;//Data:integratorstorage:ui(k-1) _iqd1;//Data:differentiatorstorage:ud(k-1) _iqd2;//Data:differentiatorstorage:d2(k-1) _iqw1;//Data:saturationrecord:[u(k-1)-v(k-1)] }PID_DATA; typedefstruct{PID_TERMINALSterm; PID_PARAMETERSparam; PID_DATAdata; }PID_CONTROLLER; /*----------------------------------------------------------------------------- DefaultinitalisationvaluesforthePIDobjects -----------------------------------------------------------------------------*/ #definePID_TERM_DEFAULTS{ 0, 0, 0, 0, 0 } #definePID_PARAM_DEFAULTS{ _IQ(1.0), _IQ(1.0), _IQ(0.0), _IQ(0.0), _IQ(1.0), _IQ(1.0), _IQ(-1.0) } #definePID_DATA_DEFAULTS{ _IQ(0.0), _IQ(0.0), _IQ(0.0), _IQ(0.0), _IQ(0.0), _IQ(0.0), _IQ(0.0), _IQ(1.0) } /*------------------------------------------------------------------------------ PIDMacroDefinition ------------------------------------------------------------------------------*/ #definePID_MACRO(v) /*proportionalterm*/ v.data.up=_IQmpy(v.param.Kr,v.term.Ref)-v.term.Fbk; /*integralterm*/ v.data.ui=_IQmpy(v.param.Ki,_IQmpy(v.data.w1, (v.term.Ref-v.term.Fbk)))+v.data.i1; v.data.i1=v.data.ui; /*derivativeterm*/ v.data.d2=_IQmpy(v.param.Kd,_IQmpy(v.term.c1, (_IQmpy(v.term.Ref,v.param.Km)-v.term.Fbk)))-v.data.d2; v.data.ud=v.data.d2+v.data.d1; v.data.d1=_IQmpy(v.data.ud,v.term.c2); /*controloutput*/ v.data.v1=_IQmpy(v.param.Kp, (v.data.up+v.data.ui+v.data.ud)); v.term.Out=_IQsat(v.data.v1,v.param.Umax,v.param.Umin); v.data.w1=(v.term.Out==v.data.v1)?_IQ(1.0):_IQ(0.0); #endif//__PID_H__

6 参考

https://en.wikipedia.org/wiki/Low-pass_filter

自动控制原理 第五版 胡寿松 P47

虽然写的不一定是最好,但是每一个字、每一个公式都是用心码的,每一张图都是用心画的,每一句话都是加入了自己的理解;另外笔者能力有限,文中难免存在错误和纰漏,望轻拍指正。

责任编辑:xj

原文标题:PID微分器与滤波器的爱恨情仇

文章出处:【微信公众号:传感器技术】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 滤波器
    +关注

    关注

    162

    文章

    8464

    浏览量

    186236
  • PID
    PID
    +关注

    关注

    38

    文章

    1505

    浏览量

    91889
  • 微分器
    +关注

    关注

    0

    文章

    16

    浏览量

    7043

原文标题:PID微分器与滤波器的爱恨情仇

文章出处:【微信号:WW_CGQJS,微信公众号:传感器技术】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    输入滤波器 vs 输出滤波器:核心差异解析

    变频输入和输出滤波器虽然只有一字之差,但它们的角色、电路设计,甚至电气特性都截然不同。简单来说,输入滤波器是为了让变频与电网“和谐相处”,而输出
    的头像 发表于 04-20 11:43 394次阅读
    输入<b class='flag-5'>滤波器</b> vs 输出<b class='flag-5'>滤波器</b>:核心差异解析

    W波段SIW滤波器

    W波段SIW滤波器
    的头像 发表于 04-17 16:31 69次阅读
    W波段SIW<b class='flag-5'>滤波器</b>

    屏蔽电源滤波器的分类

    屏蔽房用来屏蔽 辐射 干扰,而滤波器用来滤除 传导 干扰。没有滤波器,屏蔽房的整体隔离效果会下降60dB以上(相当于百万倍的效能损失),因此滤波器是屏蔽房发挥完整功能的核心部件。 来看下分类: 屏蔽
    的头像 发表于 04-16 10:53 140次阅读
    屏蔽电源<b class='flag-5'>滤波器</b>的分类

    电源滤波器的解决方案

    电源滤波器的解决方案|上海以伯电子
    的头像 发表于 04-03 13:32 179次阅读
    电源<b class='flag-5'>滤波器</b>的解决方案

    村田通信设备滤波器:特性与应用全解析

    村田通信设备滤波器:特性与应用全解析 在通信设备的设计中,滤波器是至关重要的组件,它能够有效过滤信号,确保通信的稳定性和准确性。村田(muRata)作为电子元件领域的知名企业,其推出的各类滤波器
    的头像 发表于 03-29 16:30 472次阅读

    交流单相滤波器与三相滤波器的核心区别解析

    在电力系统中,滤波器的应用至关重要,而单相滤波器和三相滤波器是其两大主要类别。这两种滤波器并非仅因相位数量不同,而是在设计原理、核心功能和应用领域上存在根本性差异。理解这些差异是进行正
    的头像 发表于 02-04 15:53 367次阅读

    村田(muRata)通信设备滤波器产品解析

    村田(muRata)通信设备滤波器产品解析 在通信设备的设计中,滤波器起着至关重要的作用,它能够有效地过滤掉不需要的信号,保证通信的质量和稳定性。村田(muRata)作为电子元件领域的知名企业,其
    的头像 发表于 01-15 17:05 777次阅读

    通信设备滤波器选型指南:Murata多层LC滤波器详解

    通信设备滤波器选型指南:Murata多层LC滤波器详解 在通信设备的设计中,滤波器是至关重要的组件,它能有效过滤掉不需要的信号,确保设备的正常运行。今天,我们就来详细了解一下村田(Murata
    的头像 发表于 01-05 17:20 833次阅读

    通信系统中滤波器的种类及特点(1)

    滤波器在通信系统中无处不在,从体积上看,有尺寸庞大的腔体滤波器,有中等的SAW滤波器,还有较小的表贴滤波器。从功能上看,毫无疑问,每种滤波器
    的头像 发表于 12-29 09:17 6441次阅读
    通信系统中<b class='flag-5'>滤波器</b>的种类及特点(1)

    电源滤波器设备超标的原因

    设备电源线上接了电源滤波器,但仍然无法通过传导骚扰电压发射测试,原因有二:骚扰强度大或滤波器安装不当。要解决这个问题,需降低骚扰强度或增大滤波器阶数。滤波器安装需远离电源入口,避免产生
    的头像 发表于 06-18 17:16 808次阅读
    电源<b class='flag-5'>滤波器</b>设备超标的原因

    有源滤波器与无源滤波器的区别

    滤波器是根据电路参数对电路频带宽度的影响而设计出来的工程应用电路,滤波器种类很多,有源滤波器和无源滤波器的区别我们最简单的分别办法是看看是否需要电源,在作用上最大的区别在于有源
    的头像 发表于 06-18 09:03 2211次阅读

    GNSS 低噪声放大器前端模块,集成前滤波器和后滤波器 skyworksinc

    电子发烧友网为你提供()GNSS 低噪声放大器前端模块,集成前滤波器和后滤波器相关产品参数、数据手册,更有GNSS 低噪声放大器前端模块,集成前滤波器和后滤波器的引脚图、接线图、封装手
    发表于 06-06 18:34
    GNSS 低噪声放大器前端模块,集成前<b class='flag-5'>滤波器</b>和后<b class='flag-5'>滤波器</b> skyworksinc

    滤波器厂家分享:开关插座式滤波器线材连接和弹片安装小技巧

    在电子设备应用中,开关插座式滤波器能有效滤除干扰信号,保障设备稳定运行。而线材连接和弹片安装这两个环节,对滤波器的性能发挥起着关键作用。下面就为大家分享一些实用的小技巧。 线材连接小技巧 线材连接前
    的头像 发表于 06-06 15:01 925次阅读

    Sky5® 低电流 GNSS LNA 前端模块,集成前置滤波器和后置滤波器 skyworksinc

    电子发烧友网为你提供()Sky5® 低电流 GNSS LNA 前端模块,集成前置滤波器和后置滤波器相关产品参数、数据手册,更有Sky5® 低电流 GNSS LNA 前端模块,集成前置滤波器和后置
    发表于 05-14 18:31
    Sky5® 低电流 GNSS LNA 前端模块,集成前置<b class='flag-5'>滤波器</b>和后置<b class='flag-5'>滤波器</b> skyworksinc