Matlab中LMI(线性矩阵不等式)工具箱使用例子

我搜出来的都是一些简单的算例,并且机会没有中文教程,我在这里就斗胆把自己的体会写出来,试着给大家提供一点参考。


LMI:Linear Matrix Inequality,就是线性矩阵不等式。
在Matlab当中,我们可以采用图形界面的lmiedit命令,来调用GUI接口,但是我认为采用程序的方式更方便(也因为我不懂这个lmiedit的GUI)。
对于LMI Lab, 其中有三种求解器(solver): feasp,mincx和gevp。
每个求解器针对不同的问题:
feasp:解决可行性问题(feasibility problem),例如:A(x)<b(x)。< font="">

mincx:在线性矩阵不等式的限制下解决最小化问题(Minimization of a linear objective under LMI constraints),例如最小化c'x,在限制条件A(x) < B(x)下。

gevp:解决广义特征值最小化问题。例如:最小化lambda,在0<b(x),a(x)<lamba*b(x)限制条件下。< font="">

要解决一个LMI问题,首要的就是要把线性矩阵不等式表示出来。


对于以下类型的任意的LMI问题


N' * L(X1, . . . , XK) * N < M' * R(X1, . . . , XK) * M


其中X1, . . . , XK是结构已经事先确定的矩阵变量。左侧和右侧的外部因子(outer factors)N和M是给定的具有相同维数的矩阵。
左侧和右侧的内部因子(inner factors)L(.)和R(.)是具有相同结构的对称块矩阵。每一个块由X1, . . . , XK以及它们的转置组合而成形成的。


解决LMI问题的步骤有两个:


1、定义维数以及每一个矩阵的结构,也就是定义X1, . . . , XK。

2、描述每一个LMI的每一项内容(Describe the term content of each LMI)

此处介绍两个术语:

矩阵变量(Matrix Variables):例如你要求解X满足A(x)<b(x),那么x就叫做矩阵< font="">

变量。

项(Terms):项是常量或者变量(Terms are either constant or variable)。

常项(Constant Terms)是确定的矩阵。可变项(Variable Terms)是哪些含有矩阵变

量的项,例如:X*A, X*C'。如果是X*A + X*C',那么记得要把它当成两项来处理。

好了废话不说了,让我们来看个例子吧(下面是一线性时滞系统)。

 

 

针对这个式子,如果存在满足如下LMI的正矩阵(positive-define)的Q,S1,S2和矩阵M,那么我们就称作

 

该系统为H-inf渐进稳定的,并且gammar是上限。

 

该论文的地址为:论文原文地址

H∞ state feedback control for generalized continuous/discrete time-delay system

 

该论文的算例为:

 

 

我们要实现的就利用LMI进行求解,验证论文结果。

 

首先我们要用setlmis([])命令初始化一个LMI系统。

 

接下来,我们就要设定矩阵变量了。采用函数为lmivar

 

语法:X = lmivar(type,struct)

type=1: 定义块对角的对称矩阵。 每一个对角块或者是全矩阵<任意对称矩阵>,标量<单位矩阵的乘积>,或者是零阵。

如果X有R个对角块,那么后面这个struct就应该是一个Rx2阶的的矩阵,在此矩阵中,struct(r,1)表示第r个块的大小,struct(r,2) 表示第r个块的类型<1--全矩阵,0--标量,-1--零阵)。

比如一个矩阵有两个对角块,其中一个是2x2的全对称矩阵,第二个是1x1的一个标量,那么该矩阵变量应该表示为X = lmivar(1, [2 1; 1 0]) 。


type=2: mxn阶的矩阵,只需要写作struct = [m,n]即可。


type=3: 其它类型。针对类型3,X的每一个条目(each entry of X)被定义为0或者是+(-)xn,此处xn代表了第n个决策变量。

那么针对我们的例子,我们如此定义变量:

% Q is a symmetric matrix, has a block size of 2 and this block is symmetric 
Q = lmivar(1, [2 1]);

% S1 a symmeric matrix, size 2 
S1 = lmivar(1, [2 1]);

% S2 is 1 by 1 matrix
S2 = lmivar(1, [1 0]);

% Type of 2, size 1 by 2 
M = lmivar(2, [1 2]);

定义完成变量之后,我们就该用lmiterm来描述LMI中的每一个项了。Matlab的官方文档提示我们,如果要描述一个LMI只需要描述上三角或者下三角元素就可以了,否则会描述成另一个LMI。

When describing an LMI with several blocks, remember to specify only the terms in the blocks on or below the diagonal (or equivalently, only the terms in blocks on or above the diagonal).

语法为:lmiterm(termID,A,B,flag)

termID是一个四维整数向量,来表示该项的位置和包含了哪些矩阵变量。

termID(1)可以为+p或者-p,+p代表了这个项位于第p个线性矩阵不等式的左边,-p代表了这个项位于第p个线性矩阵不等式的右边。注意:按照惯例来讲,左边通常指较小的那边。

termID(2:3):

1、对于外部变量来说,取值为[0,0];

2、对于左边或者右边的内部变量来说,如果该项在(i,j)位置,取值[i,j]

termID(4):

1、对于外部变量,取值为0

2、对于A*X*B,取值X

3、对于A*X'*B,取值-X

flag(可选,值为s):

因为:(A*X*B) + (A*X*B)T = A*X*B + B'*X'*A',所以采用s来进行简写。

比如:针对A*X + X'*A'

我们采用笨方法:

lmiterm([1 1 1 X],A,1) 
lmiterm([1 1 1 -X],1,A')

那么简写就是lmiterm([1 1 1 X],A,1,'s')

接下来我们就看该论文中的算例吧:(1,1)位置是

-Q+Bd*S2*Bd'+Ad*S1*Ad';

我们应该表示为:

% pos in (1, 1)
lmiterm([1 1 1 Q], -1, 1);
lmiterm([1 1 1 S2], Bd, Bd');
lmiterm([1 1 1 S1], Ad, Ad');

其它位置仿照写就行了,不懂了多看帮助文档。

把每一个项都定义以后,要记得

lmis = getlmis;

[tmin, feas] = feasp(lmis)

getlmis:是在完成定义变量和项之后,LMI系统的内部表示就可以通过此命令获得(After completing the description of a given LMI system with lmivar and lmiterm, its internal representation lmisys is obtained with the command)。

feasp是调用feasp求解器,看有没有可行解。feas就是可行解。

下面我把代码贴上去,那些常数矩阵都在此源程序中定义了。

A = [2 1; 0 1];
Ad = [0.2 0.1; 0 0.1];
B1 = [0.1 0.1]';
B2 = [1 1]';
Bd = [0.1 0.1]';

C = [1, 1];
Cd = [0.1, 0.1];

D11 = 0.1;
D12 = 1;
Dd = 0.1;

gammar = 1;

% Initial a LMI system
setlmis([]);

% Define Variables

% Q is a symmetric matrix, has a block size of 2 and this block is symmetric 
Q = lmivar(1, [2 1]);

% S1 a symmeric matrix, size 2 
S1 = lmivar(1, [2 1]);

% S2 is 1 by 1 matrix
S2 = lmivar(1, [1 0]);

% Type of 2, size 1 by 2 
M = lmivar(2, [1 2]);

% Q, S1, S2 > 0
lmiterm([-2 1 1 Q], 1, 1);

lmiterm([-3 1 1 S1], 1, 1);

lmiterm([-4 1 1 S2], 1, 1);

% pos in (1, 1)
lmiterm([1 1 1 Q], -1, 1);
lmiterm([1 1 1 S2], Bd, Bd');
lmiterm([1 1 1 S1], Ad, Ad');

% pos (1, 2)
lmiterm([1 1 2 Q], A, 1);
lmiterm([1 1 2 M], B2, 1);

% pos(1, 3)
lmiterm([1 1 3 0], B1);

% pos(1, 4)
lmiterm([1 1 4 S2], Bd, Dd');
lmiterm([1 1 4 S1], Ad, Cd');


% pos(2, 2)
lmiterm([1 2 2 Q], -1, 1);

% pos(2, 4)
lmiterm([1 2 4 Q], 1, C');

lmiterm([1 2 4 -M], 1, D12');

% pos(2, 5)
lmiterm([1 2 5 -M], 1, 1);

% pos(2, 6)
lmiterm([1 2 6 Q], 1, 1);

% pos(3, 3)
lmiterm([1 3 3 0], -(gammar^2));

% pos(3, 4)
lmiterm([1 3 4 0], D11');

% pos(4, 4)
lmiterm([1 4 4 0], -1);
lmiterm([1 4 4 S1], Cd, Cd');
lmiterm([1 4 4 S2], Dd, Dd');


lmiterm([1 5 5 S2], -1, 1);

lmiterm([1 6 6 S1], -1, 1);

lmis = getlmis;

[tmin, feas] = feasp(lmis)

 

 

运行后,就调用dec2mat把决策变量转化为矩阵形式。

Q = dec2mat(lmis, feas, Q)

Q =

    1.9253   -2.2338
   -2.2338    9.1054

可以看到,和论文中的一样。

  • 13
    点赞
  • 71
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
### 回答1: LMI VisionPro是一种广泛使用的机器视觉系统,由加拿大的LMI Technologies开发。它被广泛应用于工业自动化领域,用于实时图像处理和分析。 LMI VisionPro具备强大的图像处理功能,能够自动识别图像的物体、形状、颜色和大小等特征,并进行精确测量和定位。它可以与各种摄像机和传感器配合使用,以捕捉高质量的图像,并通过算法进行高效处理。这使得LMI VisionPro在生产线上能够实时检测产品的质量和缺陷,节省人工成本并提高生产效率。 LMI VisionPro具有友好的用户界面,使得操作和配置变得简单和直观。用户可以通过图形化界面进行参数设置和图像处理算法的调整,而无需编写复杂的代码。此外,它还提供了强大的数据分析和报告功能,帮助用户实时监控和改进生产质量。 LMI VisionPro在许多行业得到广泛应用,包括汽车制造、电子产品、医疗设备等。它可以实现对产品外观、尺寸、形状、缺陷等多个方面的检测和测量,确保产品符合规定的标准和要求。 总之,LMI VisionPro作为一种先进的机器视觉系统,结合了高质量的图像处理和强大的功能,为各种工业应用提供了全面的解决方案。它能够帮助企业实现自动化生产,并提高产品质量和生产效率。 ### 回答2: LMI VisionPro是一款先进的机器视觉软件平台。它由LMI Technologies开发,旨在提供高效、可靠的视觉解决方案。 LMI VisionPro具有强大的图像处理和分析功能,可以快速准确地识别和检测物体。它可以在各种行业和应用使用,例如自动化生产线、机器人引导、质量控制等。 LMI VisionPro提供了一整套强大的工具和算法,用于处理和分析图像。它支持各种图像处理操作,如过滤、增强、分割等。同时,它还可以对图像进行特征提取、形状匹配、颜色识别等高级分析。 LMI VisionPro还具有友好的用户界面和易用性,使操作和配置变得简单明了。它提供了图形化的编程界面,可以轻松地创建和配置应用程序。用户可以通过简单拖拽和配置工具,来创建图像处理和分析流程。 另外,LMI VisionPro还支持与各种硬件设备和传感器的集成。它可以与各种相机、激光扫描仪等设备无缝连接,并实时获取图像数据。 总之,LMI VisionPro是一款功能强大、高效可靠的机器视觉软件平台。它可以帮助用户快速准确地实现图像处理和分析,提高生产效率和质量。 ### 回答3: LMI VisionPro是一种用于机器视觉应用的先进软件系统。它由加拿大LMI公司开发,旨在帮助制造商和自动化行业提高产品质量和生产效率。 VisionPro具有强大的图像处理和分析功能,能够在工业生产过程进行高速和准确的视觉检测。它可以识别和分析图像的目标物体,检测缺陷和不良品,并对生产线进行快速的反馈和控制。 该软件系统具有用户友好的图形界面,使操作简单易学。用户可以通过图形化的编程环境创建和设置视觉检测任务,设定各种图像处理算法和参数。VisionPro还提供了各种工具和功能,如形状匹配、颜色分析、位置定位和尺寸测量等,以满足不同应用需求。 LMI VisionPro还支持不同类型的摄像头和图像采集设备,能够适应不同环境和应用场景。其可靠的性能和稳定的运行使之成为许多制造业领域的首选解决方案。 用于工业自动化的LMI VisionPro在许多领域有着广泛的应用,包括电子制造、汽车制造、食品和饮料生产等。它不仅可以提高产品质量,减少不良品数量,也可以提高生产效率,降低生产成本。随着自动化需求的不断增长,LMI VisionPro将继续在工业领域发挥重要作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值