case2off.m

来自「以上所传的内容为电力系统比较全面的分析程序,才用的是matlab编写m的文件」· M 代码 · 共 54 行

M
54
字号
function [q, p] = case2off(gen, gencost)%CASE2OFF  Creates quantity & price offers from gen & gencost.%   [q, p] = case2off(gen, gencost) creates quantity and price offers%   from case variables gen & gencost.%   MATPOWER%   $Id: case2off.m,v 1.4 2004/08/23 20:56:00 ray Exp $%   by Ray Zimmerman, PSERC Cornell%   Copyright (c) 1996-2004 by Power System Engineering Research Center (PSERC)%   See http://www.pserc.cornell.edu/matpower/ for more info.%% define named indices into data matrices[GEN_BUS, PG, QG, QMAX, QMIN, VG, MBASE, ...    GEN_STATUS, PMAX, PMIN, MU_PMAX, MU_PMIN, MU_QMAX, MU_QMIN] = idx_gen;[PW_LINEAR, POLYNOMIAL, MODEL, STARTUP, SHUTDOWN, N, COST] = idx_cost;%% do conversionoldgencost = gencost;i_poly = find(gencost(:, MODEL) == POLYNOMIAL);npts = 6;                   %% 6 points => 5 blocks%% convert polynomials to piece-wise linear by evaluating at zero and then%% at evenly spaced points between Pmin and Pmaxif any(i_poly)    [m, n] = size(gencost(i_poly, :));                              %% size of piece being changed    gencost(i_poly, MODEL) = PW_LINEAR * ones(m, 1);                %% change cost model    gencost(i_poly, COST:n) = zeros(size(gencost(i_poly, COST:n))); %% zero out old data    gencost(i_poly, N) = npts * ones(m, 1);                         %% change number of data points        for i = 1:m        ig = i_poly(i);     %% index to gen        Pmin = gen(ig, PMIN);        Pmax = gen(ig, PMAX);        if gen(ig, PMIN) == 0            step = (Pmax - Pmin) / (npts - 1);            xx = [Pmin:step:Pmax];        else            step = (Pmax - Pmin) / (npts - 2);            xx = [0 Pmin:step:Pmax];        end        yy = totcost(oldgencost(ig, :), xx);        gencost(ig,     COST:2:(COST + 2*(npts-1)    )) = xx;        gencost(ig, (COST+1):2:(COST + 2*(npts-1) + 1)) = yy;    endendn = max(gencost(:, N));xx = gencost(:,     COST:2:( COST + 2*n - 1 ));yy = gencost(:, (COST+1):2:( COST + 2*n     ));i1 = 1:(n-1);i2 = 2:n;q = xx(:, i2) - xx(:, i1);p = ( yy(:, i2) - yy(:, i1) ) ./ q;return;

⌨️ 快捷键说明

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