主要内容

利用识别技术检测系统突变

此示例显示如何使用在线估计和自动数据分段技术检测系统行为的突然变化。此示例使用系统识别工具箱™的功能,并且不需要预测性维护工具箱™。

问题描述

考虑一个传输延迟从2秒到1秒的线性系统。传输延迟是输入影响测量输出所花费的时间。在本例中,您使用在线估计和数据分割技术检测传输延迟的变化。从系统测量的输入输出数据可在数据文件中找到pdmAbruptChangesData.mat

加载并绘制数据。

负载pdmAbruptChangesData.matz = iddata(z(:,1),z(:,2));绘图(z)网格

图中包含2个轴对象。标题为y1的轴对象1包含一个类型为line的对象。这个对象表示z。标题为u1的坐标轴对象2包含一个类型为line的对象。这个对象代表z。

运输延迟的变化发生在20秒左右,但在情节中并不容易看到。

使用ARX结构对系统进行建模一个多项式系数,两B多项式系数,一个延时。

y t + 一个 y t - 1 b 1 u t - 1 + b 2 u t - 2

在这里,A = [1 A]B = [0 b1 b2]

的前导系数B多项式为零,因为该模型没有馈通。随着系统动态的变化,三个系数的值一个b1,b2改变。什么时候b1,则有效运输延迟为2个样本,因为B多项式有两个前导零。什么时候b1较大,有效的运输延迟将是1个样品。

因此,要检测到运输延迟的变化,您可以监控更改B多项式系数。

使用在线估计进行变更检测

在线估计算法以递归的方式更新模型参数和状态估计,因为有新的数据可用。您可以使用系统识别工具箱库中的Simulink块执行在线估计,或者在命令行中使用金宝app递归识别例程,例如recursiveARX.在线估计可用于模拟时变动力学,例如老化机械和改变天气模式,或者检测机电系统中的故障。

当估计器更新模型参数时,系统动力学的变化(延迟)将表现为参数值的变化大于通常的变化b1b2.的变化B计算多项式系数将通过计算跟踪:

l t 一个 b 年代 B t - B t - 1

使用recursiveARX对象在线估计ARX模型的参数。

na = 1;NB = 2;nk = 1;估计器= revsusiveAlex([na nb nk]);

指定递归估计算法为标准化的并且适应增益为0.9。

估计量。EstimationMethod =“NormalizedGradient”;估计量。一个daptationGain = .9;

从中提取原始数据iddata对象,z

输出= z.OutputData;输入= z.InputData;t = z.SamplingInstants;N =长度(t);

使用动画行绘制估计的参数值和l.在估计之前初始化这些动画行。为了模拟流数据,一次将数据馈送到估计器一个样本。在估计之前初始化模型参数,然后执行在线估计。

%%初始化图颜色= {“r”'G'“b”};甘氨胆酸ax =;班(ax)K = 3:-1:1 h(K) = animatedline“颜色”、颜色{k});%行用于a, b1和b2参数结尾h (4) = animatedline ('标记'“。”“颜色”,[0 0 0]);L的%行传奇({“一个”“b1”“b2”'偏差'},'地点''东南') 标题(“ARX递归参数估计”)包含(的时间(秒)) ylabel (的参数值斧头。XLim = [t(1),(最终)];斧子。YLim = [1,2];网格盒子%%现在执行递归估计并显示结果n0 = 6;L =南(N、nk);B_old =南(1、3);ct = 1:N [A,B] = step(Estimator,Output(ct),Input(ct));如果ct>n0 L(ct) = norm(B-B_old);B_old = B;结尾addpoints(h(1),t(ct),a(2))addpoints(h(2),t(ct),b(2))addpoints(h(3),t(ct),b(3))Addpoints(H(4),T(CT),L(CT))暂停(0.1)结尾

图中包含一个轴对象。标题为ARX递归参数估计的axis对象包含4个类型为animatedline的对象。这些对象代表a, b1, b2,偏移。

首先N0.= 6数据样本不用于计算变化检测器,l.在此区间内,由于初始条件未知,参数变化较大。

找出所有山峰的位置l通过使用findpeaks来自信号处理工具箱的命令。

(v, Loc) = findpeaks (L);[~,我]= max (v);线(t (Loc (I)), L (Loc (I)),“父”,斧头,'标记'“o”“MarkerEdgeColor”“r”...'markerfacecolor''是'“MarkerSize”, 12)

图中包含一个轴对象。标题为ARX递归参数估计的axis对象包含5个类型为animatedline, line的对象。这些对象代表a, b1, b2,偏移。

流('在样本数%d.\n检测到系统延迟变化'疯狂的(我));
在样本号21处检测到的系统延迟变化。

最大峰值的位置对应于最大的变化B多项式系数,因此是传输延迟发生变化的位置。

在线估计技术为估计方法和模型结构的选择提供了更多的选择,而数据分割方法有助于对突变和孤立变化的自动检测。

使用数据分割进行变更检测

数据分割算法自动将数据分割成不同动态行为的区域。这对于捕获由于故障或操作条件变化而引起的突然变化非常有用。的命令用于单次输出数据的操作。当您不需要捕获系统运行期间的时变行为时,是在线估计技术的一种替代方法。

数据分割的应用包括语音信号的分割(每一段对应一个音素)、故障检测(每段对应有故障和无故障的操作)以及系统不同工作模式的估计。

的输入命令包括测量的数据,模型订单,以及对方差的猜测,r2,影响系统的噪声。如果方差完全未知,则可以自动估计。使用与在线估计相同的订单的ARX模型执行数据分段。将方差设置为0.1。

[seg,V,tvmod] = segment(z,[na nb nk],0.1);

分割方法基于AFMM(通过多种模型的自适应忘记)。有关该方法的详细信息,请参阅Andersson,INT。J.控制1985年11月。

多模型方法用于跟踪时变系统。得到的跟踪模型是多个模型的平均值,并且作为第三个输出参数返回tvmod

绘制跟踪模型的参数。

情节(TVMOD)传奇({“一个”“b_1”'b_2'},“位置”'最好的事物')包含(“样本”),Ylabel(的参数值) 标题('时变估计'

图中包含一个轴对象。具有标题时变估计的轴对象包含3个类型的线。这些对象代表A,B_1,B_2。

请注意这些参数轨迹和那些使用估计的轨迹之间的相似性recursiveARX

确定使用更改时的时间点tvmod,即模型出现突变的概率。通过对跟踪模型进行平滑处理,利用这些时间点来构建分段模型。

返回分段模型的参数值赛格,第一个输出参数.每个连续行的值是底层分段模型在相应时刻的参数值。这些值在连续的行中保持不变,只有在确定系统动态发生变化时才会更改。因此,值赛格是分段常数。

绘制参数的估计值一个b1,b2

情节(SEG)标题(参数值段的)({传奇“一个”“b1”“b2”},“位置”'最好的事物')包含(的时间(秒)) ylabel (的参数值

图中包含一个轴对象。带有标题参数值segments的axes对象包含3个类型为line的对象。这些对象代表a b1 b2。

在示例第19页周围的参数值中看到了一个变化。值b1从一个小值(接近0)到一个大值(接近1)。的价值b2显示相反的模式。这种变化的值B参数表示传输延迟的变化。

的第二个输出参数V,是分段模型的损失函数(即分段模型的估计预测误差方差)。您可以使用V对分割模型的质量进行评估。

注意,分割算法的两个最重要的输入是r2的第四个输入参数.在这个例子中,没有指定,因为默认值0.01就足够了。较小的值r2和更大的值将导致更多的分割点。为了找到合适的值,您可以改变r2并使用最佳工作的人。通常,分割算法对其更敏感r2

结论

评估了用于检测系统动态的突然变化的在线估计和数据分段技术。在线估计技术提供更多灵活性和更多对估计过程的控制。但是,对于罕见或突然的变化,促进了一种基于平滑的时变参数估计的自动检测技术。

相关的话题