基于卡尔曼滤波器的PID控制-1

news2024/9/23 22:57:44

采用M语言对算例进行仿真!!

设置控制对象传递函数:

取采样时间为1ms,采用Z变换将对象离散化,并描述为离散状态方程的形式:

x(k +1)= Ax(k)+ B(u(k)+wk))

y(k)= Cx(k)

带有测量噪声的被控对象输出为:

yv(k)=Cx(k)+ v(k)

控制干扰信号w(k)和测量噪声信号v(k)幅值均为0.10的白噪声信号,输入信号幅值为1.0、频率为1.5Hz的正弦信号。采用卡尔曼滤波器实现信号的滤波,取Q=1,R=1。仿真时间为3s,原始信号及带有噪声的原始信号、原始信号及滤波后的信号和误差协方差的变化分别如图1~ 3所示。仿真结果表明,该滤波器对控制干扰和测量噪声具有很好的滤波作用。

图1 原始信号及带有噪声的原始信号

图2 原始信号及滤波后的信号

图3 误差协方差的变化

仿真程序:

%Kalman filter

%x=Ax+B(u+w(k));

%y-Cx+D+v(k)

clear all;

close all;

ts=0.001;

M=3000;

%Continuous Plant

a=25;b=133;

sys=tf(b,[1,a,0D);

dsys=c2d(sys,ts,z);

[num.den]=tfdata(dsys,'v');

A1=[0 1;0 -a];

B1=[0;b];

C1=[1 0];

D1=[0];

[A,B,C,D]=c2dm(A1,B1.CI,D1,ts,'zZ);

Q=1; %Covariances of w

R=1; %Covariances of v

P=B*Q*B'; %Initial error covariance

x=zeros(2,1); %Initial condition on the state

ye=zeros(M,1);

ycov=zeros(M,1);

u_1=0;u_2=0;

y_1=0;y_2=0;

for k=1:1;M

time(k)=k*ts;

w(k)=0.10*rands( 1); %Process noise on u

v(k)=0.10*rands(1); %Mcasurement noise on y

u(k)=1.0*sin(2*pi*1.5*k*ts);

u(k)=u(k)+w(k);

y(k)=-den(2)*y_1-den(3)*y_2+num(2)*u1+num(3)*u_2;yv(k)-y(k)+v(k);

%Measurement update

Mn=P*C(C*P*C'+R);P=A*P*A+B*Q*B';P=(eye(2)-Mn*C)*P;

x=A*x+Mn*(yv(k)-C*A*x);

ye(k)-C*x+D; %Filtered value

errcov(k)-C*P*C; %Covariance ofestimation error

%Time update

x=A*x+B*u(k);

u_2=u_1;u_1=u(k);y_2=y_1:y 1=ye(k);

end

figure(1);

plot(time,y,'r, time,yv,k:','linewidth’,2);

xlabel('time(s));ylabel('y.yv')

legend(ideal signal','signal with noise');

figure(2);

plot(time,y,'r,time,ye,'k:' linewidth',2);

xlabel( 'time(s)':ylabel('y, ye')

legend(ideal signal','filtered signal');

figure(3);

plot(time,errcov 'k'. Tinewidth' 2);

xlabel( 'time(s)';ylabel('Covariance of estimation error');

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/187669.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Ubuntu18.04下安装OpenCV4.2.0与Opencv_contrib(图文详细报错总结)

Ubuntu18.04下安装OpenCV4.2.0与Opencv_contrib(图文详细)前期准备—环境依赖Cmake(编译器)依赖环境Python环境streamer环境图像处理依赖安装OpenCV编译OpenCV配置cmake编译参数make编译配置OpenCV动态库验证OpenCV环境# python环…

724. 寻找数组的中心下标——你行吗???

兄弟们,今早遇到了一个题,案例看起来很简单,于是就尝试起来,求知己😭题目描述724. 寻找数组的中心下标难度简单511收藏分享切换为英文接收动态反馈给你一个整数数组 nums ,请计算数组的 中心下标 。数组 中…

一文了解 Java 中 so 文件的加载原理

前言 无论是 Android 开发者还是 Java 工程师应该都有使用过 JNI 开发,但对于 JVM 如何加载 so、Android 系统如何加载 so,可能鲜有时间了解。 本文通过代码、流程解释,带大家快速了解其加载原理,扫清困惑。 1. System#load() …

3.1.2 访问控制符及修饰符

文章目录1.访问控制符2.静态字段/方法/代码块2.1 静态字段2.2 静态常量2.3 静态方法2.4 特点2.5 static入门案例2.6 静态的调用关系2.7 静态代码块2.7.1 格式2.7.2 特性:2.7.3 执行顺序2.7.4 案例练习3.final的概念3.1 特点3.2 final入门案例1.访问控制符 在JAVA中…

【HBase——陌陌海量存储案例】8. 基于Phoenix消息数据查询(下)

索引示例二:创建本地索引 需求 在程序中,我们可能会根据订单ID、订单状态、支付金额、支付方式、用户ID来查询订单。所以,我们需要在这些列上来查询订单。 针对这种场景,我们可以使用本地索引来提高查询效率。 创建本地索引 cre…

超全小程序开发的学习 知识点

第一章:邂逅小程序开发 01_小程序开发和各个平台小程序的介绍 小程序加载的时候是双线程模型.wxml文件和wxss文件是一个线程,js和json文件是一个线程。 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mEP3PUoo-1675132790458…

七步让您的MySQL服务器更安全

本文将以最常见的数据库管理系统——MySQL为例,向您介绍如何通过7步骤来安全加固数据库服务器。 不知您是否发现一种现象,那些初学渗透测试的人员往往过于关注应用的安全性,而对数据库的安全性不太重视。他们殊不知,没有数据库的…

上海亚商投顾:兔年首日开门红 北向资金净流入超186亿

上海亚商投顾前言:无惧大盘涨跌,解密龙虎榜资金,跟踪一线游资和机构资金动向,识别短期热点和强势个股。市场情绪两市早盘受外围影响大幅高开,随后指数高开低走,板块及个股相对活跃,汽车产业链&a…

视频图像分析处理流程(完整版)

来源:投稿 作者:LSC 编辑:学姐 一、视频分析处理的完整流程 (1)视频编解码的入门知识 尽管压缩工具五花八门,但是他们的目的都只有一个:都是为了减小文件的占用空间。 除去我们常见的.zip,.7z&#xff0…

MyBatis框架如何实现数据查询?有几种方法?

在实际开发中,查询操作通常都会涉及到单条数据的精确查询,以及多条数据的模糊查询。那么使用MyBatis框架是如何进行这两种查询的呢?接下来,本小节将讲解下如何使用MyBatis框架根据客户编号查询客户信息,以及根据客户名…

【前沿技术】在安全且可靠的区块链基础设施中运行业务条线应用

发表时间:2022年4月27日 信息来源:coingeek.com 了解特定企业的业务需求将使你能够构建出一个可扩容的业务条线应用,它将按照你想要的方式进行运作,并在不可篡改的BSV区块链中保存相关记录。 大多数企业都有一个业务条线&#xf…

《吐血整理》保姆级系列教程-玩转Fiddler抓包教程(1)-HTTP和HTTPS基础知识

1.简介 有的小伙伴或者童鞋们可能会好奇地问,不是讲解和分享抓包工具了怎么这里开始讲解HTTP和HTTPS协议了。这是因为你对HTTP协议越了解,你就能越掌握Fiddler的使用方法,反过来你越使用Fiddler,就越能帮助你了解HTTP协议。 Fid…

HashMap原理分析

HashMap原理分析JDK7 HashMap1、模型介绍2、底层实现原理3、描述一下put的过程4、HashMap扩容机制:5、HashMap中的循环链表是如何产生的6、HashMap和HashTable的区别7、HashMap为什么用红黑树而不用B树?JDK8 HashMapJDK7 HashMap 1、模型介绍 HashMap在…

18. time和calendar模块

当代码中需要使用到时间时,我们通常会使用time模块来获取当前时间或者时间戳。 时间戳:从1970年1月1日(UTC/GMT的午夜)开始所经过的秒数,不考虑闰秒。 1. 时间戳 获取当前时间戳: import timeprint(time…

Springboot+vue预约上门维修服务系统

前端技术:nodejsvueelementui一般是采用前后端分离模式, 后端支持python/php/java/nodejs MTV模式 M:model,模型,负责与数据库交互 V:view,视图是核心,负责接收请求、获取数据、返回结果 T:template&…

并发编程学习(八):ReentrantLock特性、哲学家吃饭问题

ReentrantLock 是java.util.concurrent.locks包下的类。相对于synchronized,它具备如下特性:可中断。可以设置超时时间。可以设置公平锁。支持多个条件变量。即可以有个多个waitset等待队列。与synchronized都支持可重入。ReentrantLock的基本语法:// 获…

c++11 标准模板(STL)(std::multiset)(二)

定义于头文件 <set>template< class Key, class Compare std::less<Key>, class Allocator std::allocator<Key> > class multiset;(1)namespace pmr { template <class Key, class Compare std::less<Key>> using…

Day12【元宇宙的实践构想01】—— 元宇宙概念和发展历程

&#x1f483;&#x1f3fc; 本人简介&#xff1a;男 &#x1f476;&#x1f3fc; 年龄&#xff1a;18 ✍每日一句&#xff1a;【道固远&#xff0c;笃行可至&#xff1b;事虽巨&#xff0c;坚为必成】 &#x1f6a9; 今日留言&#xff1a;亮亮被迫去练科目二啦&#xff0c;定时…

K8S架构熟悉及日常操作

目录 一、架构介绍 二、组件介绍 三、调度介绍 四、CLI指令介绍 五、常见CLI指令 六、常见问题排查思路 一、架构介绍 Kubernetes系统架构为客户端/服务端&#xff08;C/S&#xff09;架构&#xff0c;Master作为服务端&#xff0c;Node作为客户端。 Master服务端也被称…

学习逆向安全的必备基础: 汇编的初步了解

什么是汇编 汇编语言是一种低级编程语言&#xff0c;它使用简单的助记符来表示计算机底层的机器指令。 汇编语言是直接与计算机硬件交互的&#xff0c;它能够控制计算机中的每一个细节。 由于汇编语言非常低级&#xff0c;所以编写汇编程序通常比较困难。不过&#xff0c;汇…