pennonm_callback_dg.m

来自「matlab波形优化算法经常要用到的matlab toolbox工具箱:yalm」· M 代码 · 共 45 行

M
45
字号
function [nnz,ind,val] = pennonm_callback_dg(i,x,model_in)

global latest_G
global latest_g
global latest_x_g

persistent model
persistent G

if nargin>2
    model = model_in;
    return
end

x = x(:);
if ~isequal(latest_x_g,x) 
    % Compute the nonlinear terms in the constraints
    [g,geq,dg,dgeq] = fmincon_con(x,model);
    latest_x_g = x;
    
    % Append with linear constraints
    g = [g;geq];
    if ~isempty(model.A)
        g = [g;model.A*x - model.b];
    end
    if ~isempty(model.Aeq)
        g = [g;model.Aeq*x - model.beq];
    end
        
    % Append with linear terms
    G = [dg';dgeq'];
    if ~isempty(model.A)
        G = [G;model.A];
    end
    if ~isempty(model.Aeq)
        G = [G;model.Aeq];
    end
    latest_G = G;
    latest_g = g;
else
    G = latest_G;
end
Gi = G(i+1,:);
[aux,ind,val] = find(Gi);
nnz = length(val);

⌨️ 快捷键说明

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