ADRC-跟踪微分器TD的Maltab实现及参数整定

目录

问题描述:

跟踪微分器TD基本概念:

Matlab及其实现:

跟踪效果:

例1:跟踪信号 sin(t) +0.5*rand(1,1)。

例2:跟踪部分时段为方波的信号,具体形式见代码get_command。

参数整定:

参考文献


问题描述:

在设计飞行器姿态控制器的过程中,参考指令为方波形式,致使信号不连续处的导数发生较大变化,严重影响了依赖于参考指令导数及其二阶导数的控制器(如SMC)的鲁棒性。因此,尝试借助自抗扰控制中的跟踪微分器实现信号及其对时间的导数的平滑处理。

跟踪微分器TD基本概念:

跟踪微分器(Tracking Differentiator, TD) 是“自抗扰控制器”(ADRC)[3] 的组成部分,最早由韩京清老师提出。提出的目的是为了解决在实际问题中,从不连续(如方波)或带随机噪声(如模型不确定性或外部干扰)的参考信号中,合理提取连续信号及微分信号的问题。简单来说,就是平滑化信号。在实际应用中,我们所得到的信号往往是带有噪声的,为了从这些含噪信号中提取或恢复原始信号,就需要设计滤波器,以得到原始信号的最佳逼近 [1],因此TD可视为滤波器。

Matlab及其实现:

本文所实现的离散化TD参考了韩京清老师发表在《系统仿真学报》上的论文《跟踪微分器滤波性能研究》,参数设置较原文有所调整,复现结果可跟踪下文示例信号。

将下述代码放到同一目录下即可运行,Matlab版本为2022a,程序入口为main.m函数。

main.m

% 测试微分跟踪器.
clear,clc;

%% 初始化, 生成跟踪信号.
T = 0.01;  %积分步长.
End = 30;
tf = 0:T:End;    %跟踪时长.

%例程1
a = -1; b = 1;
v = sin(tf) + 0.5*(a + (b-a)*rand(1,1));

%例程2
%v = zeros(1, length(tf));
% for i = 1:length(tf)
%     v(i) = get_command(1 + i*T, End);
% end

x1 = zeros(1, length((v)));
x2 = zeros(1, length((v)));


%% 使用TD获取处理后的信号及其微分.
for i = 1:length(v)
    [x1(1, i), x2(1, i)] = TD(v(i), T);
end


%% 绘制信号.
close all;

figure
plot(tf, v, tf, x1, tf, x2);
xlabel('time'), ylabel('signal'), legend('原始输入 v', '跟踪输入x1', '跟踪输入导数x2' )

figure
subplot(3,1,1);
plot(tf,v);
legend('原始输入 v')
xlabel('time'), ylabel('signal');

subplot(3,1,2);
plot(tf,x1);
legend('跟踪输入x1')
xlabel('time'), ylabel('signal');

subplot(3,1,3);
plot(tf,x2)
legend('跟踪输入导数x2' )
xlabel('time'), ylabel('signal');


%% 参考文献
% [1]武利强,林浩,韩京清.跟踪微分器滤波性能研究[J].系统仿真学报, 2004, 16(4):3.DOI:10.3969/j.issn.1004-731X.2004.04.012.
% [2]https://blog.csdn.net/m0_37764065/article/details/108668033.  %复制链接得去掉最后的.

fst.m

function f=fst(v, x1_k, x2_k, r, h1, r2)
% fst = −r*sat(g(k),delta), 快速控制最优综合函数, 也称fhan函数
delta = h1*r;			%h1为滤波因子  r为调节系数,r越大跟踪效果越好,但微分信号会增加高频噪声
delta1 = delta*h1;	    %反之,微分信号越平滑,会产生一定的滞后
e_k = x1_k-v;
y_k = e_k + r2*h1*x2_k;

g_k = g(x2_k, y_k, delta, delta1, r, h1);
f = -r*sat(g_k, delta);


%% 局部函数
function g_k = g(x2_k, y_k, delta, delta1, r, h1)
a0=sqrt(delta^2 + 8*r*abs(y_k));

if abs(y_k) >= delta1
    g_k = x2_k + (a0-delta)*sign(y_k)/2;
else
    g_k = x2_k + y_k/h1; 
end


function f = sat(x, delta)
if abs(x)>=delta
    f = sign(x);
else
    f = x/delta;
end

TD.m

function [x1_, x2_] = TD(v, T)
% v 是原始期望指令, x2 = x1_dot, x1是滤波后的指令, T为积分步长.
% T = 0.01;  %积分步长, , 韩老师文章记作h.
r = 1000;    %决定跟踪快慢的参数.
r2 = 1;      %
h = 0.01;  %滤波性能与相位损失之间的权衡参数.
h1 = 8*h;

persistent x1 x2;   %仅函数内部可见的全局变量.

% 初始化变量.
if isempty(x1)
    x1 = v;
end
if isempty(x2)
    x2 = 0;
end
x1_k = x1;
x2_k = x2;

% TD 的离散化公式.
% x1(k+1) = x1(k) + h*x2(k)
% x2(k+1) = x2(k) + h*fst(x1(k)-v(k), x2(k), r, h1)
x1 = x1_k + T*x2_k;
x2 = x2_k + T*fst(v, x1_k, x2_k, r, h1, r2); %因为x1k是逐步算出的,故单独传入x1(k)与v(k)

% 输出
x1_ = x1;
x2_ = x2;
end

get_command.m

function X_d = get_command(t, End)
%alpha_c为攻角控制指令
%beta_c为侧滑角控制指令
%sigma_c为倾侧角控制指令

t_1 = 8;
t_2 = 20;

alpha_1 = 18;
alpha_2 = 15;
alpha_3 = 10;


sigma_1 = 20;
sigma_2 = -15;


% 
if t < t_2
alpha_c = alpha_1 * (t < t_1) + getdot(alpha_1, alpha_2, t_1, End, t) * (t >= t_1 && t < t_2); 
beta_c = 0;
sigma_c = sigma_1 * (t < t_1) + getdot(sigma_1, sigma_2, t_1, End, t) * (t >= t_1 && t < t_2);

% 函数指令
aero_angle_d            = [alpha_c beta_c sigma_c]';           %姿态角指令 弧度制 单位/rad
%aero_angle_d_dot        = [((alpha_1-alpha_2)/Simu.tf-t_1)*pi/180 0 ((sigma_1-sigma_2)/Simu.tf-t_1)*pi/180]';       %姿态角指令一阶导
aero_angle_d_dot        = [0 0 0]';       %姿态角指令一阶导
aero_angle_d_dot_dot    = [0 0 0]';     %姿态角指令二阶导

else
alpha_c = alpha_2; 
beta_c = 0;
sigma_c = 0;

% 函数指令
aero_angle_d            = [alpha_c beta_c sigma_c]';           %姿态角指令 弧度制 单位/rad
aero_angle_d_dot        = [0 0 0]';       %姿态角指令一阶导
aero_angle_d_dot_dot    = [0 0 0]';     %姿态角指令二阶导
end


% X_d                     = [aero_angle_d; aero_angle_d_dot; aero_angle_d_dot_dot]';
X_d = aero_angle_d(1);


function angle = getdot(angle1, angle2, t1, t2, t)
% 姿态角控制指令计算
%  angle为姿态角控制指令输出
%  angle1为初始时刻姿态角,angle2为结束时刻姿态角
%  t1为初始时刻,t2为结束时刻,t为当前时刻

angle = (angle2 - angle1)/(t2 - t1)*(t - t1) + angle1;

跟踪效果:

例1:跟踪信号 sin(t) +0.5*rand(1,1)。

例2:跟踪部分时段为方波的信号,具体形式见代码get_command。

参数整定:

跟踪指令处处连续平滑(如正弦波),则应该选用较小的h值;反之,则选用稍大的h值,通常选取在[0.01, 0.001]之间。通过调整h的指改变h1的值,h1 越大,会增大跟踪信号与参考信号之间的相位损失,越小,则滤波效果越好。

参考文献

[1]武利强,林浩,韩京清.跟踪微分器滤波性能研究[J].系统仿真学报, 2004, 16(4):3.DOI:10.3969/j.issn.1004-731X.2004.04.012.

[2]https://blog.csdn.net/m0_37764065/article/details/108668033. 

[3]薛定宇, 陈阳泉. 基于 MATLAB/Simulink 系统仿真技术与应用
[M]. 北京: 清华大学出版社, 2002.

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

⭐Unity 读取本地图片再区域裁剪

现在需求是将本地的图片读取之后再区域截图成新的图片 话不多说直接上代码 using UnityEngine; using System.IO;public class LocalRegionCapture : MonoBehaviour {public string fullScreenImagePath "Assets/SavedImages/fullScreenScreenshot.png";public str…

蓝桥杯2020年5月青少组Python程序设计国赛真题

1、 上边是一个算法流程图,最后输出的b的值是() A.377 B.987 C.1597 D.2584 2、 3、如果整个整数X本身是完全平方数,同时它的每一位数字也都是完全平方数我们就称X 是完美平方数。前几个完美平方数是0、1、4、9、49、100、144......即第1个完美平方数是0,第2个是 1,第3个…

问卷调查反应偏差消除技巧:提高数据准确性的实用方法

回应偏差会对您的调查结果产生不利影响。以下是您可以采取的措施来对抗偏差。调查之所以成为一个有力的工具&#xff0c;是因为它能够获取关于目标受众的真实信息和数据&#xff0c;而不是依靠试错方法。然而&#xff0c;为了使这些数据有用&#xff0c;它必须是无误差的&#…

SAP PP 配置学习(四)

分类 维护类的层次 分配 批量更改特征值

如何使用设计模式来解决类与类之间调用过深的问题。

我们将使用责任链模式和装饰者模式的组合。 考虑一个简化的餐厅订单处理系统&#xff0c;其中包括服务员&#xff08;Waiter&#xff09;、厨师&#xff08;Chef&#xff09;和收银员&#xff08;Cashier&#xff09;。订单从服务员开始&#xff0c;然后传递给厨师&#xff0c…

JUC并发编程 09——队列同步器AQS

目录 一.Lock接口 1.1Lock的使用 1.2Lock接口提供的 synchronized 不具备的主要特性 1.3Lock接口的所有方法 二.队列同步器(AQS) 2.1队列同步器的接口与示例 2.2AQS实现源码分析 ①同步队列 ②获取锁 ③释放锁 一.Lock接口 说起锁&#xff0c;你肯定会想到 synchron…

css 超过一行/多行显示省略号... - 附示例

效果 1、超过一行 2、超过多行 - 以两行为例 二、示例代码 1、超过一行 margin: 20px; width: 50px; border: 1px solid red; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; 2、超过多行 - 以两行为例 margin: 20px; width: 50px; border: 1px solid r…

docker小白第八天

docker小白第八天 redis常规安装 前期已经配好了阿里云容器镜像加速库 docker search redis docker pull redis:6.0.8 docker images redis:6.0.8启动容器,并进入容器的命令行界面 docker run -d -p 6379:6379 redis:6.0.8 docker ps docker exec -it 容器id /bin/bash验证…

202362读书笔记|《茉莉花》——时间滤去一切伤痛,让智慧和美好永垂不朽

202362读书笔记|《茉莉花》——时间滤去一切伤痛&#xff0c;让智慧和美好永垂不朽 《茉莉花》作者卓凌&#xff0c;插图美&#xff0c;文字也好读的一本诗集&#xff0c;很值得一读&#xff01; 部分节选如下&#xff1a; 生活是一列穿山越岭的火车&#xff1b;享受过程&#…

老用户可买:腾讯云轻量应用服务器2核2G4M带宽118元一年,3年540元

它急了&#xff0c;腾讯云急了&#xff0c;继阿里云推出99元新老用户同享的云服务器后&#xff0c;腾讯云轻量应用服务器2核2G4M配置也支持新老用户同享了&#xff0c;一年118元&#xff0c;3年540元&#xff0c;老用户也能买&#xff0c;50GB SSD系统盘&#xff0c;300GB 月流…

计算机毕业设计 基于SpringBoot的高校竞赛管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解

博主介绍&#xff1a;✌从事软件开发10年之余&#xff0c;专注于Java技术领域、Python人工智能及数据挖掘、小程序项目开发和Android项目开发等。CSDN、掘金、华为云、InfoQ、阿里云等平台优质作者✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f447;&#x1f3fb; 精…

模式识别与机器学习-特征选择和提取

模式识别与机器学习-特征选择和提取 特征选择一些距离测度公式独立特征的选择准则一般特征的散布矩阵准则 离散K-L变换 谨以此博客作为复习期间的记录。 常见分类问题的流程&#xff0c;数据预处理和特征选择提取时机器学习环节中最重要的两个流程。这两个环节直接决定了最终性…

初见 Amazon Q

前言 如果今年要写一篇年终总结的话&#xff0c;生成式 Ai 一定是绕不过的一个话题&#xff0c;自从去年的 chatGPT 火爆全球后&#xff0c;今年各种生成式 Ai 的产品络绎不绝地出现大众视线&#xff0c;版本迭代的速度也是非常快&#xff0c;大家甚至开始在自己的生活和工作中…

SpringBoot整合Spring-Security 认证篇(保姆级教程)

本文项目基于以下教程的代码版本&#xff1a; https://javaxbfs.blog.csdn.net/article/details/135195636 代码仓库: https://gitee.com/skyblue0678/springboot-demo 为了跟shiro区别开&#xff0c;新建了一个分支&#xff1a; 目录 &#x1f339;1、友善问候一下 Spring …

【HBase】——简介

1 HBase 定义 Apache HBase™ 是以 hdfs 为数据存储的&#xff0c;一种分布式、可扩展的 NoSQL 数据库。 2 HBase 数据模型 • HBase 的设计理念依据 Google 的 BigTable 论文&#xff0c;论文中对于数据模型的首句介绍。 Bigtable 是一个稀疏的、分布式的、持久的多维排序 m…

万字长文谈自动驾驶bev感知(一)

文章目录 prologuepaper listcamera bev :1. Lift, Splat, Shoot: Encoding Images from Arbitrary Camera Rigs by Implicitly Unprojecting to 3D2. M2BEV: Multi-Camera Joint 3D Detection and Segmentation with Unified Birds-Eye View Representation3. BEVDet: High-Pe…

Oracle开发经验总结

文章目录 1. 加注释2. 增加索引3. nvl(BOARDCODE&#xff0c;100)>004. 去掉distinct可以避免hash比较&#xff0c;提高性能5. like模糊查询优化(转化为instr()函数)6. SQL计算除数为0时&#xff0c;增加nullif判断7. 分页8. 查看执行计划9. <if test"productCode !…

231227-9步在RHEL8.8配置本地yum源仓库

Seciton 1&#xff1a;参考视频 RHEL8配置本地yum源仓库-安徽迪浮_哔哩哔哩_bilibili Seciton 2&#xff1a;具体操作 &#x1f3af; 第1步&#xff1a;查看光驱文件/dev/sr0是否已经挂载&#xff1f;此处已挂在 [lgklocalhost ~]$ df -h &#x1f3af; 第1步&#xff1a;查看…

SQL语句中的函数和高级语句

目录 SQL语句中的函数 数学函数 聚合函数 字符串函数 SQL语句中的高级语句 SELECT ​编辑 DISTINCT ​编辑 WHERE AND OR IN BETWEEN 通配符 LIKE ORDER BY GROUP BY HAVING 别名 子查询 EXISTS 连接查询 UNION 交集值 无交集值 视图 SQL语句中的函数 数学函数 abs…

[Ray Tracing: The Next Week] 笔记

前言 本篇博客参照自《Ray Tracing: The Next Week》教程&#xff0c;地址为&#xff1a;https://raytracing.github.io/books/RayTracingTheNextWeek.html 该教程在ray tracing in one weekend的基础上&#xff0c;增加了运动模糊、BVH树、Texture映射、柏林噪声、光照、体积…