⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 unblkdiag.m

📁 国外专家做的求解LMI鲁棒控制的工具箱,可以相对高效的解决LMI问题
💻 M
字号:
function sys = unblkdiag(F)
% UNBLOCKDIAG Extracts diagonal blocks
%
% G = unblkdiag(F) Detects and converts block diagonal SDP.
%
% See also DISSECT

% Author Johan L鰂berg
% $Id: unblkdiag.m,v 1.3 2005/06/17 13:02:01 joloef Exp $

switch class(F)
    case 'lmi'
        sys = set([]);
        for i = 1:length(F)
            if is(F(i),'sdp') % SDP
                Z = sdpvar(F(i));
                X = spy(Z);
                [v,dummy,r,dummy2]=dmperm(X);
                if v==dummy & length(r)>2
                    linearblocks = []; % Simple diagonal terms;
                    for blocks = 1:length(r)-1
                        r1 = r(blocks);
                        r2 = r(blocks+1)-1;
                        if r2>r1
                            sys = sys + set(Z(v(r1:r2),v(r1:r2)));
                        else
                            linearblocks = [linearblocks v(r1)];
                        end
                    end
                    if ~isempty(linearblocks)
                        D=diag(Z);
                        sys = sys+set(D(linearblocks));
                    end
                else
                    sys = sys + F(i);                    
                end
            else
                sys = sys + F(i);
            end
        end
    case 'sdpvar'
        sys = {};
        Z = F;
        X = spy(Z);
        [v,dummy,r,dummy2]=dmperm(X);
        if v==dummy & length(r)>2
            for blocks = 1:length(r)-1
                r1 = r(blocks);
                r2 = r(blocks+1)-1;
                sys{end+1} = Z(v(r1:r2),v(r1:r2));
            end
        else
            sys{1} = Z;
        end
end
end

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -