亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? lmi.m

?? 求解線性矩陣不等式簡單方便--與LMI工具箱相比
?? M
字號:
function F = lmi(X,handlestring,dummy,noprune,symmetryKnown)
% The command lmi is obsolete, see help sdpvar/set

% Author Johan L鰂berg
% $Id: lmi.m,v 1.26 2006/09/22 08:11:45 joloef Exp $

%superiorto('sdpvar')

fast = 0;
noprune = 0;
symmetryKnown = 0;
switch nargin
    case 0
        F.clauses={};
        F.LMIid    = [];
        F.savedata = [];
        F = class(F,'lmi');
        return
    case 1
        handlestring = '';
        % ok probably, check later
    case 2
        if ~isa(handlestring,'char')
            error('The handle must be a string')
        end
    case 4
        handlestring = '';
        noprune = 1;
    case 5
        handlestring = '';
        symmetryKnown = 1;

    otherwise
        error('Wrong number of arguments')
end

F.clauses  = {};
F.LMIid    = [];
F.savedata = [];

try
    F = class(F,'lmi');
catch
    disp('Failure in creating SET object. Restart MATLAB and try again, or type clear classes')
end

% Return empty LMI in degenerate case
if isempty(X)
    return
end

% 0 : Nothing (i.e error)
% 1 : LMI
% 2 : Elementwise
% 3 : Equality
% 4 : SOCC
% 5 : Rotated Lorentz
% 9 : KYP constraint
%10 : Eigenvalue constraint
%11 : Sum of square constraint
%12 : Logic CNF
%14 : Uncertain variable
switch class(X)
    case 'lmi'
        F = X;
        return
    case 'char'
        try
            % Parse (check for old notation, take care of ||...|| notation)
            sdpvarExpr = parseLMI(X);
            % Old notation
            X = strrep(X,'.>','>');
            X = strrep(X,'.<','<');
            %   X = strrep(X,'=','==');X = strrep(X,'====','==');
        catch
            error(lasterr)
        end
        % Evaluate
        try
            Fi=evalin('caller',sdpvarExpr);
            switch class(Fi)
                case 'sdpvar'
                    Fi = {Fi};
                    strict = 0;
                case 'constraint'
                    [Fi,strict] = getlist(Fi);
                otherwise
                    error('The string does not define an SDPVAR object')
            end

        catch
            error(lasterr)
        end

    case 'sdpvar'
        Fi = {X};
        strict = 0;
        X='Numeric value';

    case 'logic'
        Fi = {X};
        strict = 0;
        X = 'Numeric value';

    case 'constraint'
        [Fi,strict] = getlist(X);
        X='Numeric value';

    otherwise
        error('The first argument should be an sdpvar object or string.')
end

% Return empty LMI in degenerate case
if all(cellfun('isempty',Fi))
    return
end

TypeofConstraint = zeros(length(Fi),1)-1;

% support for SOS constraints placed in vector
if length(Fi) == 1
    if is(Fi{1},'sos')
        % Expand to a set of SOS constraints
        if ~issymmetric(Fi{1})
            p = Fi{1}(:);
            for i = 1:length(p)
                Fi{i} = p(i);
            end
            TypeofConstraint = zeros(length(Fi),1)-1;
            strict = zeros(length(Fi),1)-1;
        end
    end
end

i = 1;
while i <= length(Fi)
    thisFi = Fi{i};
    if ~isempty(thisFi)
        if isa(thisFi,'logic')
            TypeofConstraint(i) = 12;
        else
            TypeofConstraint(i) = gethackflag(Fi{i});
        end
        % User just sent a sdpvar object, interpret as X>0
        if (TypeofConstraint(i)==0)
            TypeofConstraint(i) = 1;
        end

        if (TypeofConstraint(i)==1) & (symmetryKnown == 0)
            [n,m]=size(thisFi);
            if (n~=m) | ((TypeofConstraint(i) == 1) & (n*m==1)) | ~ishermitian(thisFi)
                TypeofConstraint(i) = 2;
            end
        end

        if TypeofConstraint(i) == 2

            % remove constraint of the type set(0 >= 0)
            B = getbase(thisFi);
            if 0
                % Detect constraint set(negative number >= 0)
                % removed due to problems with mpt toolbox
                candidates = find(B(:,1) < 0);
                if ~isempty(candidates)
                    Bv = B(candidates,2:end);
                    dummy = any(Bv,2);
                    used = find(dummy);
                    if length(used) < size(Bv,1)
                        thisFi = thisFi(candidates(used));
                        if any(B(candidates(find(~dummy)),1) < 0)
                            % error('Trivially infeasible : There are negative constants in this element-wise constraint.');
                        end
                    end
                end
            end
            if ~noprune
                Bv = B(:,2:end);
                notused = find((~any(Bv,2)) & (B(:,1)>=0));
                if ~isempty(notused)
                    used = setdiff(1:size(Bv,1),notused);%find(any(Bv,2))
                    %                    if length(used)<size(Bv,1)
                    thisFi = thisFi(used);
                    %                   end
                end
            end
        end

        % save cleaned version
        Fi{i} = thisFi;

        switch TypeofConstraint(i)
            case {1,2,3,4,5,7,8,9,10,11,12,13,15}
                i = i + 1;
            otherwise
                error('Error in argument in LMI. Please report bug');
        end
    end
end

% Special case for x<y<z<...
% Merge into one constraint, gives nicer displays
if all(TypeofConstraint == 2) & all(strict==strict(1))
    if length(Fi)>1
        vecF = [];
        sizes = zeros(length(Fi),1);
        % Speed up concatenation of merging
        for i = 1:length(Fi)
            sizes(i) = prod(size(Fi{i}));
        end
        if all(sizes == 1)
            vecF = [Fi{:}]';
        else
            for i = 1:length(Fi)
                fi = Fi{i};
                if sizes(i) > 1
                    %             fi = Fi{i};fi = reshape(fi,sizes(i),1);
                    fi = reshape(fi,prod(size(fi)),1);
                end
                vecF = [vecF;fi];
            end
        end
    else
        vecF = reshape(Fi{1},prod(size(Fi{1})),1);
    end
    F.clauses{1}.data=vecF;
    F.clauses{1}.type = 2;
    F.clauses{1}.symbolic=X;
    F.clauses{1}.handle=handlestring;
    F.clauses{1}.strict = strict(1);
    F.clauses{1}.cut = 0;
    F.clauses{1}.expanded = 0;
    F.clauses{1}.lift = 0;
    F.LMIid = [F.LMIid yalmip('lmiid')];
else
    %start = yalmip('lmiid');
    for i = 1:length(Fi)
        switch TypeofConstraint(i)
            case {1,2,3,4,5,7,8,9,10,11,12,13,15}
                F.clauses{i}.data=Fi{i};
                F.clauses{i}.type = TypeofConstraint(i);
                F.clauses{i}.symbolic=X;
                F.clauses{i}.handle=handlestring;
                F.clauses{i}.strict = strict(i);
                F.clauses{i}.cut = 0;
                F.clauses{i}.expanded = 0;
                F.clauses{i}.lift = 0;
                F.LMIid = [F.LMIid yalmip('lmiid')];
                i = i + 1;
            otherwise
                error('Error in argument in LMI. Please report bug');
        end
    end
end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩丝袜美女视频| 精品国产露脸精彩对白| 亚洲国产aⅴ天堂久久| 欧美亚洲国产bt| 日韩中文字幕区一区有砖一区| 制服丝袜亚洲色图| 国内精品视频666| 国产精品区一区二区三| 91在线国内视频| 天天做天天摸天天爽国产一区| 日韩欧美在线观看一区二区三区| 精品一区二区三区视频| 中文字幕不卡三区| 欧美国产日韩a欧美在线观看 | 老鸭窝一区二区久久精品| www国产精品av| jlzzjlzz国产精品久久| 亚洲一区二区三区精品在线| 日韩欧美国产精品| 成人h动漫精品| 91精品福利视频| 日韩色在线观看| 国产成人精品一区二区三区四区| 国产精品每日更新| 欧美日韩电影一区| 国产酒店精品激情| 亚洲黄色录像片| 日韩精品中文字幕在线不卡尤物 | 激情五月播播久久久精品| 国产精品久久久久久久久动漫 | 国产91精品露脸国语对白| 亚洲综合无码一区二区| 精品处破学生在线二十三| 99久久婷婷国产精品综合| 首页国产欧美日韩丝袜| 欧美激情在线看| 欧美乱妇15p| 国产91精品在线观看| 午夜日韩在线电影| 欧美韩国日本一区| 欧美人牲a欧美精品| 国产成人在线观看| 日韩国产欧美在线观看| 国产精品久久久爽爽爽麻豆色哟哟| 欧美区视频在线观看| 风流少妇一区二区| 热久久一区二区| 1024成人网| 欧美精品一区二区三区在线播放 | 99国产精品国产精品毛片| 日韩—二三区免费观看av| 国产精品激情偷乱一区二区∴| 欧美日韩小视频| 成人深夜视频在线观看| 免费在线观看一区| 亚洲精品成a人| 国产色产综合产在线视频| 欧美久久一二三四区| 99v久久综合狠狠综合久久| 老司机午夜精品| 亚洲成av人片一区二区三区| 国产精品亲子乱子伦xxxx裸| 欧美成人aa大片| 欧美色精品在线视频| 国产.欧美.日韩| 久久精品国产亚洲高清剧情介绍 | 亚洲永久精品大片| 中文字幕精品—区二区四季| 日韩欧美国产精品| 欧美日韩激情一区| 一本久道中文字幕精品亚洲嫩| 国产一区二区三区电影在线观看 | 欧美日韩一区二区在线观看| 不卡一区二区三区四区| 国产一本一道久久香蕉| 视频一区欧美日韩| 一区二区三区视频在线看| 国产精品私房写真福利视频| 精品免费日韩av| 在线综合亚洲欧美在线视频| 在线视频一区二区三| 99久久精品免费看国产| 精品日韩欧美在线| 欧美写真视频网站| 91蜜桃婷婷狠狠久久综合9色| 国产黄色成人av| 国内久久婷婷综合| 麻豆国产欧美日韩综合精品二区| 亚洲一区二区三区四区在线| 亚洲精品国产第一综合99久久 | 亚洲成人在线网站| 伊人婷婷欧美激情| 亚洲久本草在线中文字幕| 国产精品国产自产拍高清av王其| 久久精品一区四区| 久久精品欧美一区二区三区麻豆| 精品国产免费视频| 精品精品国产高清a毛片牛牛| 欧美一级免费大片| 91精品国产综合久久久久久久| 欧美日韩中文字幕一区二区| 在线观看精品一区| 欧美午夜精品电影| 欧美日韩美少妇| 欧美女孩性生活视频| 欧美久久高跟鞋激| 在线综合+亚洲+欧美中文字幕| 6080yy午夜一二三区久久| 这里只有精品99re| 国产精品原创巨作av| 国产精品成人免费| 国产精品美女久久久久aⅴ| 欧美激情中文字幕一区二区| 国产亚洲精久久久久久| 欧美高清在线精品一区| 中文字幕免费观看一区| 国产精品麻豆一区二区| 亚洲品质自拍视频| 亚洲一卡二卡三卡四卡| 午夜激情一区二区三区| 日韩av一二三| 国内精品伊人久久久久av影院| 国产麻豆精品一区二区| 丁香婷婷综合色啪| av不卡免费电影| 色婷婷激情综合| 欧美日韩一二三| 欧美一区二区三区不卡| 精品国产乱码久久久久久图片 | 精品91自产拍在线观看一区| 精品国产91洋老外米糕| 国产亚洲精品超碰| 韩国av一区二区| 成人av在线资源网| 欧洲在线/亚洲| 日韩一区二区免费高清| www国产成人免费观看视频 深夜成人网| 国产亚洲一区二区三区| 日韩伦理免费电影| 天堂成人免费av电影一区| 卡一卡二国产精品| 成人午夜电影网站| 欧洲精品一区二区| 日韩欧美国产一区二区在线播放| 久久精品一级爱片| 一区二区三区在线视频观看58| 午夜成人免费视频| 国产精品资源站在线| 91首页免费视频| 69久久99精品久久久久婷婷| 国产日韩综合av| 夜夜精品浪潮av一区二区三区| 日本不卡1234视频| 成人免费观看av| 欧美日韩国产首页在线观看| 精品国产制服丝袜高跟| **欧美大码日韩| 日韩精品亚洲专区| 国产成人免费网站| 在线观看亚洲一区| 日韩一级免费观看| 中文字幕中文在线不卡住| 亚洲成a天堂v人片| 国产aⅴ综合色| 欧美日本韩国一区| 日本一区二区综合亚洲| 亚洲成人精品影院| 国产麻豆成人精品| 欧美日韩一区二区在线观看视频| 久久综合久久99| 亚洲国产视频一区| 国产成人免费网站| 在线成人免费视频| 国产精品久久久久久久裸模| 日韩激情一二三区| 本田岬高潮一区二区三区| 91精品国产欧美日韩| 亚洲天堂成人网| 久久精品72免费观看| 中文字幕一区二区三区av| 日韩精品一级二级| 色综合欧美在线视频区| 26uuu久久天堂性欧美| 亚洲一区二区三区视频在线播放| 国产精品原创巨作av| 欧美高清精品3d| 亚洲欧美偷拍卡通变态| 国产一区美女在线| 欧美高清精品3d| 亚洲精品国产a| 成人福利视频网站| 精品三级在线看| 婷婷国产在线综合| 色综合激情久久| 欧美国产国产综合| 久久99国产乱子伦精品免费| 欧美日免费三级在线| 麻豆成人久久精品二区三区红| 美女网站一区二区| 91精彩视频在线|